/usr/bin/java -ea -Xmx8000000000 -Xss4m -jar ./plugins/org.eclipse.equinox.launcher_1.5.800.v20200727-1323.jar -data @noDefault -ultimatedata ./data --core.log.level.for.class de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPusher=WARN -tc ../../../trunk/examples/toolchains/AutomizerC.xml -s ../../../trunk/examples/settings/automizer/acceleratedInterpolation/acceleratedInterpolationQvasr_64.epf -i ../../../trunk/examples/svcomp/nla-digbench-scaling/hard2_valuebound50.c -------------------------------------------------------------------------------- This is Ultimate 0.2.2-dev-34549b5 [2022-04-08 13:23:41,174 INFO L177 SettingsManager]: Resetting all preferences to default values... [2022-04-08 13:23:41,175 INFO L181 SettingsManager]: Resetting UltimateCore preferences to default values [2022-04-08 13:23:41,210 INFO L184 SettingsManager]: Ultimate Commandline Interface provides no preferences, ignoring... [2022-04-08 13:23:41,211 INFO L181 SettingsManager]: Resetting Boogie Preprocessor preferences to default values [2022-04-08 13:23:41,225 INFO L181 SettingsManager]: Resetting Boogie Procedure Inliner preferences to default values [2022-04-08 13:23:41,229 INFO L181 SettingsManager]: Resetting Abstract Interpretation preferences to default values [2022-04-08 13:23:41,233 INFO L181 SettingsManager]: Resetting LassoRanker preferences to default values [2022-04-08 13:23:41,235 INFO L181 SettingsManager]: Resetting Reaching Definitions preferences to default values [2022-04-08 13:23:41,238 INFO L181 SettingsManager]: Resetting SyntaxChecker preferences to default values [2022-04-08 13:23:41,239 INFO L181 SettingsManager]: Resetting Sifa preferences to default values [2022-04-08 13:23:41,240 INFO L184 SettingsManager]: Büchi Program Product provides no preferences, ignoring... [2022-04-08 13:23:41,240 INFO L181 SettingsManager]: Resetting LTL2Aut preferences to default values [2022-04-08 13:23:41,242 INFO L181 SettingsManager]: Resetting PEA to Boogie preferences to default values [2022-04-08 13:23:41,243 INFO L181 SettingsManager]: Resetting BlockEncodingV2 preferences to default values [2022-04-08 13:23:41,244 INFO L181 SettingsManager]: Resetting ChcToBoogie preferences to default values [2022-04-08 13:23:41,244 INFO L181 SettingsManager]: Resetting AutomataScriptInterpreter preferences to default values [2022-04-08 13:23:41,245 INFO L181 SettingsManager]: Resetting BuchiAutomizer preferences to default values [2022-04-08 13:23:41,248 INFO L181 SettingsManager]: Resetting CACSL2BoogieTranslator preferences to default values [2022-04-08 13:23:41,252 INFO L181 SettingsManager]: Resetting CodeCheck preferences to default values [2022-04-08 13:23:41,253 INFO L181 SettingsManager]: Resetting HornVerifier preferences to default values [2022-04-08 13:23:41,254 INFO L181 SettingsManager]: Resetting InvariantSynthesis preferences to default values [2022-04-08 13:23:41,255 INFO L181 SettingsManager]: Resetting RCFGBuilder preferences to default values [2022-04-08 13:23:41,255 INFO L181 SettingsManager]: Resetting Referee preferences to default values [2022-04-08 13:23:41,256 INFO L181 SettingsManager]: Resetting TraceAbstraction preferences to default values [2022-04-08 13:23:41,268 INFO L184 SettingsManager]: TraceAbstractionConcurrent provides no preferences, ignoring... [2022-04-08 13:23:41,268 INFO L184 SettingsManager]: TraceAbstractionWithAFAs provides no preferences, ignoring... [2022-04-08 13:23:41,268 INFO L181 SettingsManager]: Resetting TreeAutomizer preferences to default values [2022-04-08 13:23:41,269 INFO L181 SettingsManager]: Resetting IcfgToChc preferences to default values [2022-04-08 13:23:41,269 INFO L181 SettingsManager]: Resetting IcfgTransformer preferences to default values [2022-04-08 13:23:41,270 INFO L184 SettingsManager]: ReqToTest provides no preferences, ignoring... [2022-04-08 13:23:41,270 INFO L181 SettingsManager]: Resetting Boogie Printer preferences to default values [2022-04-08 13:23:41,270 INFO L181 SettingsManager]: Resetting ChcSmtPrinter preferences to default values [2022-04-08 13:23:41,270 INFO L181 SettingsManager]: Resetting ReqPrinter preferences to default values [2022-04-08 13:23:41,271 INFO L181 SettingsManager]: Resetting Witness Printer preferences to default values [2022-04-08 13:23:41,271 INFO L184 SettingsManager]: Boogie PL CUP Parser provides no preferences, ignoring... [2022-04-08 13:23:41,271 INFO L181 SettingsManager]: Resetting CDTParser preferences to default values [2022-04-08 13:23:41,272 INFO L184 SettingsManager]: AutomataScriptParser provides no preferences, ignoring... [2022-04-08 13:23:41,272 INFO L184 SettingsManager]: ReqParser provides no preferences, ignoring... [2022-04-08 13:23:41,272 INFO L181 SettingsManager]: Resetting SmtParser preferences to default values [2022-04-08 13:23:41,272 INFO L181 SettingsManager]: Resetting Witness Parser preferences to default values [2022-04-08 13:23:41,274 INFO L188 SettingsManager]: Finished resetting all preferences to default values... [2022-04-08 13:23:41,276 INFO L101 SettingsManager]: Beginning loading settings from /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/../../../trunk/examples/settings/automizer/acceleratedInterpolation/acceleratedInterpolationQvasr_64.epf [2022-04-08 13:23:41,285 INFO L113 SettingsManager]: Loading preferences was successful [2022-04-08 13:23:41,285 INFO L115 SettingsManager]: Preferences different from defaults after loading the file: [2022-04-08 13:23:41,286 INFO L136 SettingsManager]: Preferences of CACSL2BoogieTranslator differ from their defaults: [2022-04-08 13:23:41,286 INFO L138 SettingsManager]: * Overapproximate operations on floating types=true [2022-04-08 13:23:41,286 INFO L138 SettingsManager]: * Check division by zero=IGNORE [2022-04-08 13:23:41,286 INFO L138 SettingsManager]: * Pointer to allocated memory at dereference=IGNORE [2022-04-08 13:23:41,286 INFO L138 SettingsManager]: * If two pointers are subtracted or compared they have the same base address=IGNORE [2022-04-08 13:23:41,286 INFO L138 SettingsManager]: * Check array bounds for arrays that are off heap=IGNORE [2022-04-08 13:23:41,286 INFO L138 SettingsManager]: * Check if freed pointer was valid=false [2022-04-08 13:23:41,287 INFO L138 SettingsManager]: * Use constant arrays=true [2022-04-08 13:23:41,287 INFO L138 SettingsManager]: * Pointer base address is valid at dereference=IGNORE [2022-04-08 13:23:41,287 INFO L136 SettingsManager]: Preferences of RCFGBuilder differ from their defaults: [2022-04-08 13:23:41,287 INFO L138 SettingsManager]: * Size of a code block=SequenceOfStatements [2022-04-08 13:23:41,287 INFO L138 SettingsManager]: * To the following directory=./dump/ [2022-04-08 13:23:41,288 INFO L138 SettingsManager]: * SMT solver=External_DefaultMode [2022-04-08 13:23:41,288 INFO L138 SettingsManager]: * Command for external solver=z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 [2022-04-08 13:23:41,288 INFO L136 SettingsManager]: Preferences of TraceAbstraction differ from their defaults: [2022-04-08 13:23:41,288 INFO L138 SettingsManager]: * Compute Interpolants along a Counterexample=Craig_NestedInterpolation [2022-04-08 13:23:41,288 INFO L138 SettingsManager]: * Trace refinement strategy=ACCELERATED_INTERPOLATION [2022-04-08 13:23:41,288 INFO L138 SettingsManager]: * Trace refinement strategy used in Accelerated Interpolation=CAMEL [2022-04-08 13:23:41,288 INFO L138 SettingsManager]: * Compute Hoare Annotation of negated interpolant automaton, abstraction and CFG=true [2022-04-08 13:23:41,288 INFO L138 SettingsManager]: * Loop acceleration method that is used by accelerated interpolation=QVASR [2022-04-08 13:23:41,288 INFO L138 SettingsManager]: * Use separate solver for trace checks=false WARNING: An illegal reflective access operation has occurred WARNING: Illegal reflective access by com.sun.xml.bind.v2.runtime.reflect.opt.Injector$1 (file:/storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/plugins/com.sun.xml.bind_2.2.0.v201505121915.jar) to method java.lang.ClassLoader.defineClass(java.lang.String,byte[],int,int) WARNING: Please consider reporting this to the maintainers of com.sun.xml.bind.v2.runtime.reflect.opt.Injector$1 WARNING: Use --illegal-access=warn to enable warnings of further illegal reflective access operations WARNING: All illegal access operations will be denied in a future release Applying setting for plugin de.uni_freiburg.informatik.ultimate.core: Log level for class -> de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPusher=WARN; [2022-04-08 13:23:41,486 INFO L75 nceAwareModelManager]: Repository-Root is: /tmp [2022-04-08 13:23:41,507 INFO L261 ainManager$Toolchain]: [Toolchain 1]: Applicable parser(s) successfully (re)initialized [2022-04-08 13:23:41,509 INFO L217 ainManager$Toolchain]: [Toolchain 1]: Toolchain selected. [2022-04-08 13:23:41,510 INFO L271 PluginConnector]: Initializing CDTParser... [2022-04-08 13:23:41,510 INFO L275 PluginConnector]: CDTParser initialized [2022-04-08 13:23:41,511 INFO L432 ainManager$Toolchain]: [Toolchain 1]: Parsing single file: /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/../../../trunk/examples/svcomp/nla-digbench-scaling/hard2_valuebound50.c [2022-04-08 13:23:41,559 INFO L220 CDTParser]: Created temporary CDT project at /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/46eaac153/c35e7aae76c6494fbdcb68ab58b1ba62/FLAGee6cffc55 [2022-04-08 13:23:41,898 INFO L306 CDTParser]: Found 1 translation units. [2022-04-08 13:23:41,898 INFO L160 CDTParser]: Scanning /storage/repos/ultimate/trunk/examples/svcomp/nla-digbench-scaling/hard2_valuebound50.c [2022-04-08 13:23:41,903 INFO L349 CDTParser]: About to delete temporary CDT project at /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/46eaac153/c35e7aae76c6494fbdcb68ab58b1ba62/FLAGee6cffc55 [2022-04-08 13:23:41,915 INFO L357 CDTParser]: Successfully deleted /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/46eaac153/c35e7aae76c6494fbdcb68ab58b1ba62 [2022-04-08 13:23:41,917 INFO L299 ainManager$Toolchain]: ####################### [Toolchain 1] ####################### [2022-04-08 13:23:41,918 INFO L131 ToolchainWalker]: Walking toolchain with 4 elements. [2022-04-08 13:23:41,928 INFO L113 PluginConnector]: ------------------------CACSL2BoogieTranslator---------------------------- [2022-04-08 13:23:41,928 INFO L271 PluginConnector]: Initializing CACSL2BoogieTranslator... [2022-04-08 13:23:41,931 INFO L275 PluginConnector]: CACSL2BoogieTranslator initialized [2022-04-08 13:23:41,932 INFO L185 PluginConnector]: Executing the observer ACSLObjectContainerObserver from plugin CACSL2BoogieTranslator for "CDTParser AST 08.04 01:23:41" (1/1) ... [2022-04-08 13:23:41,933 INFO L205 PluginConnector]: Invalid model from CACSL2BoogieTranslator for observer de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator.ACSLObjectContainerObserver@48615b8d and model type de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 08.04 01:23:41, skipping insertion in model container [2022-04-08 13:23:41,933 INFO L185 PluginConnector]: Executing the observer CACSL2BoogieTranslatorObserver from plugin CACSL2BoogieTranslator for "CDTParser AST 08.04 01:23:41" (1/1) ... [2022-04-08 13:23:41,941 INFO L145 MainTranslator]: Starting translation in SV-COMP mode [2022-04-08 13:23:41,952 INFO L178 MainTranslator]: Built tables and reachable declarations [2022-04-08 13:23:42,065 WARN L230 ndardFunctionHandler]: Function reach_error is already implemented but we override the implementation for the call at /storage/repos/ultimate/trunk/examples/svcomp/nla-digbench-scaling/hard2_valuebound50.c[526,539] [2022-04-08 13:23:42,077 INFO L210 PostProcessor]: Analyzing one entry point: main [2022-04-08 13:23:42,090 INFO L203 MainTranslator]: Completed pre-run [2022-04-08 13:23:42,098 WARN L230 ndardFunctionHandler]: Function reach_error is already implemented but we override the implementation for the call at /storage/repos/ultimate/trunk/examples/svcomp/nla-digbench-scaling/hard2_valuebound50.c[526,539] [2022-04-08 13:23:42,104 INFO L210 PostProcessor]: Analyzing one entry point: main [2022-04-08 13:23:42,112 INFO L208 MainTranslator]: Completed translation [2022-04-08 13:23:42,113 INFO L202 PluginConnector]: Adding new model de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 08.04 01:23:42 WrapperNode [2022-04-08 13:23:42,113 INFO L132 PluginConnector]: ------------------------ END CACSL2BoogieTranslator---------------------------- [2022-04-08 13:23:42,114 INFO L113 PluginConnector]: ------------------------Boogie Preprocessor---------------------------- [2022-04-08 13:23:42,114 INFO L271 PluginConnector]: Initializing Boogie Preprocessor... [2022-04-08 13:23:42,114 INFO L275 PluginConnector]: Boogie Preprocessor initialized [2022-04-08 13:23:42,121 INFO L185 PluginConnector]: Executing the observer EnsureBoogieModelObserver from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 08.04 01:23:42" (1/1) ... [2022-04-08 13:23:42,122 INFO L185 PluginConnector]: Executing the observer TypeChecker from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 08.04 01:23:42" (1/1) ... [2022-04-08 13:23:42,126 INFO L185 PluginConnector]: Executing the observer ConstExpander from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 08.04 01:23:42" (1/1) ... [2022-04-08 13:23:42,126 INFO L185 PluginConnector]: Executing the observer StructExpander from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 08.04 01:23:42" (1/1) ... [2022-04-08 13:23:42,130 INFO L185 PluginConnector]: Executing the observer UnstructureCode from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 08.04 01:23:42" (1/1) ... [2022-04-08 13:23:42,133 INFO L185 PluginConnector]: Executing the observer FunctionInliner from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 08.04 01:23:42" (1/1) ... [2022-04-08 13:23:42,134 INFO L185 PluginConnector]: Executing the observer BoogieSymbolTableConstructor from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 08.04 01:23:42" (1/1) ... [2022-04-08 13:23:42,135 INFO L132 PluginConnector]: ------------------------ END Boogie Preprocessor---------------------------- [2022-04-08 13:23:42,136 INFO L113 PluginConnector]: ------------------------RCFGBuilder---------------------------- [2022-04-08 13:23:42,136 INFO L271 PluginConnector]: Initializing RCFGBuilder... [2022-04-08 13:23:42,136 INFO L275 PluginConnector]: RCFGBuilder initialized [2022-04-08 13:23:42,141 INFO L185 PluginConnector]: Executing the observer RCFGBuilderObserver from plugin RCFGBuilder for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 08.04 01:23:42" (1/1) ... [2022-04-08 13:23:42,146 INFO L173 SolverBuilder]: Constructing external solver with command: z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 [2022-04-08 13:23:42,153 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-08 13:23:42,163 INFO L229 MonitoredProcess]: Starting monitored process 1 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 (exit command is (exit), workingDir is null) [2022-04-08 13:23:42,181 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 (1)] Waiting until timeout for monitored process [2022-04-08 13:23:42,198 INFO L138 BoogieDeclarations]: Found implementation of procedure ULTIMATE.init [2022-04-08 13:23:42,198 INFO L138 BoogieDeclarations]: Found implementation of procedure ULTIMATE.start [2022-04-08 13:23:42,198 INFO L138 BoogieDeclarations]: Found implementation of procedure reach_error [2022-04-08 13:23:42,198 INFO L138 BoogieDeclarations]: Found implementation of procedure assume_abort_if_not [2022-04-08 13:23:42,199 INFO L138 BoogieDeclarations]: Found implementation of procedure __VERIFIER_assert [2022-04-08 13:23:42,199 INFO L138 BoogieDeclarations]: Found implementation of procedure main [2022-04-08 13:23:42,199 INFO L130 BoogieDeclarations]: Found specification of procedure abort [2022-04-08 13:23:42,199 INFO L130 BoogieDeclarations]: Found specification of procedure __assert_fail [2022-04-08 13:23:42,199 INFO L130 BoogieDeclarations]: Found specification of procedure reach_error [2022-04-08 13:23:42,200 INFO L130 BoogieDeclarations]: Found specification of procedure #Ultimate.allocInit [2022-04-08 13:23:42,200 INFO L130 BoogieDeclarations]: Found specification of procedure __VERIFIER_nondet_int [2022-04-08 13:23:42,200 INFO L130 BoogieDeclarations]: Found specification of procedure assume_abort_if_not [2022-04-08 13:23:42,200 INFO L130 BoogieDeclarations]: Found specification of procedure __VERIFIER_assert [2022-04-08 13:23:42,200 INFO L130 BoogieDeclarations]: Found specification of procedure main [2022-04-08 13:23:42,201 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.init [2022-04-08 13:23:42,202 INFO L130 BoogieDeclarations]: Found specification of procedure write~init~int [2022-04-08 13:23:42,202 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.start [2022-04-08 13:23:42,202 INFO L130 BoogieDeclarations]: Found specification of procedure write~int [2022-04-08 13:23:42,202 INFO L130 BoogieDeclarations]: Found specification of procedure read~int [2022-04-08 13:23:42,202 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.dealloc [2022-04-08 13:23:42,247 INFO L234 CfgBuilder]: Building ICFG [2022-04-08 13:23:42,248 INFO L260 CfgBuilder]: Building CFG for each procedure with an implementation [2022-04-08 13:23:42,355 INFO L275 CfgBuilder]: Performing block encoding [2022-04-08 13:23:42,360 INFO L294 CfgBuilder]: Using the 1 location(s) as analysis (start of procedure ULTIMATE.start) [2022-04-08 13:23:42,360 INFO L299 CfgBuilder]: Removed 2 assume(true) statements. [2022-04-08 13:23:42,362 INFO L202 PluginConnector]: Adding new model de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 08.04 01:23:42 BoogieIcfgContainer [2022-04-08 13:23:42,362 INFO L132 PluginConnector]: ------------------------ END RCFGBuilder---------------------------- [2022-04-08 13:23:42,363 INFO L113 PluginConnector]: ------------------------TraceAbstraction---------------------------- [2022-04-08 13:23:42,363 INFO L271 PluginConnector]: Initializing TraceAbstraction... [2022-04-08 13:23:42,365 INFO L275 PluginConnector]: TraceAbstraction initialized [2022-04-08 13:23:42,365 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "CDTParser AST 08.04 01:23:41" (1/3) ... [2022-04-08 13:23:42,366 INFO L205 PluginConnector]: Invalid model from TraceAbstraction for observer de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionObserver@1bfd3f15 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction AST 08.04 01:23:42, skipping insertion in model container [2022-04-08 13:23:42,366 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 08.04 01:23:42" (2/3) ... [2022-04-08 13:23:42,366 INFO L205 PluginConnector]: Invalid model from TraceAbstraction for observer de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionObserver@1bfd3f15 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction AST 08.04 01:23:42, skipping insertion in model container [2022-04-08 13:23:42,366 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 08.04 01:23:42" (3/3) ... [2022-04-08 13:23:42,367 INFO L111 eAbstractionObserver]: Analyzing ICFG hard2_valuebound50.c [2022-04-08 13:23:42,370 INFO L203 ceAbstractionStarter]: Automizer settings: Hoare:true NWA Interpolation:Craig_NestedInterpolation Determinization: PREDICATE_ABSTRACTION [2022-04-08 13:23:42,370 INFO L162 ceAbstractionStarter]: Applying trace abstraction to program that has 1 error locations. [2022-04-08 13:23:42,399 INFO L339 AbstractCegarLoop]: ======== Iteration 0 == of CEGAR loop == AllErrorsAtOnce ======== [2022-04-08 13:23:42,403 INFO L340 AbstractCegarLoop]: Settings: SEPARATE_VIOLATION_CHECK=true, mInterprocedural=true, mMaxIterations=1000000, mWatchIteration=1000000, mArtifact=RCFG, mInterpolation=Craig_NestedInterpolation, mInterpolantAutomaton=STRAIGHT_LINE, mDumpAutomata=false, mAutomataFormat=ATS_NUMERATE, mDumpPath=., mDeterminiation=PREDICATE_ABSTRACTION, mMinimize=MINIMIZE_SEVPA, mHoare=true, mAutomataTypeConcurrency=FINITE_AUTOMATA, mHoareTripleChecks=INCREMENTAL, mHoareAnnotationPositions=All, mDumpOnlyReuseAutomata=false, mLimitTraceHistogram=0, mErrorLocTimeLimit=0, mLimitPathProgramCount=0, mCollectInterpolantStatistics=true, mHeuristicEmptinessCheck=false, mHeuristicEmptinessCheckAStarHeuristic=ZERO, mHeuristicEmptinessCheckAStarHeuristicRandomSeed=1337, mHeuristicEmptinessCheckSmtFeatureScoringMethod=DAGSIZE, mSMTFeatureExtraction=false, mSMTFeatureExtractionDumpPath=., mOverrideInterpolantAutomaton=false, mMcrInterpolantMethod=WP [2022-04-08 13:23:42,403 INFO L341 AbstractCegarLoop]: Starting to check reachability of 1 error locations. [2022-04-08 13:23:42,416 INFO L276 IsEmpty]: Start isEmpty. Operand has 35 states, 19 states have (on average 1.5263157894736843) internal successors, (29), 20 states have internal predecessors, (29), 10 states have call successors, (10), 4 states have call predecessors, (10), 4 states have return successors, (10), 10 states have call predecessors, (10), 10 states have call successors, (10) [2022-04-08 13:23:42,431 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 18 [2022-04-08 13:23:42,431 INFO L491 BasicCegarLoop]: Found error trace [2022-04-08 13:23:42,432 INFO L499 BasicCegarLoop]: trace histogram [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-08 13:23:42,432 INFO L403 AbstractCegarLoop]: === Iteration 1 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-08 13:23:42,443 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-08 13:23:42,443 INFO L85 PathProgramCache]: Analyzing trace with hash -977830905, now seen corresponding path program 1 times [2022-04-08 13:23:42,458 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-08 13:23:42,459 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [1810144383] [2022-04-08 13:23:42,466 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-08 13:23:42,466 INFO L85 PathProgramCache]: Analyzing trace with hash -977830905, now seen corresponding path program 2 times [2022-04-08 13:23:42,468 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-08 13:23:42,469 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1608735335] [2022-04-08 13:23:42,469 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-08 13:23:42,469 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-08 13:23:42,576 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:23:42,636 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 0 [2022-04-08 13:23:42,647 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:23:42,667 INFO L290 TraceCheckUtils]: 0: Hoare triple {47#(and (= |#NULL.offset| |old(#NULL.offset)|) (= |old(#NULL.base)| |#NULL.base|))} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {38#true} is VALID [2022-04-08 13:23:42,667 INFO L290 TraceCheckUtils]: 1: Hoare triple {38#true} assume true; {38#true} is VALID [2022-04-08 13:23:42,668 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {38#true} {38#true} #94#return; {38#true} is VALID [2022-04-08 13:23:42,668 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 6 [2022-04-08 13:23:42,671 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:23:42,678 INFO L290 TraceCheckUtils]: 0: Hoare triple {38#true} ~cond := #in~cond; {38#true} is VALID [2022-04-08 13:23:42,679 INFO L290 TraceCheckUtils]: 1: Hoare triple {38#true} assume 0 == ~cond;assume false; {39#false} is VALID [2022-04-08 13:23:42,679 INFO L290 TraceCheckUtils]: 2: Hoare triple {39#false} assume true; {39#false} is VALID [2022-04-08 13:23:42,679 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {39#false} {38#true} #78#return; {39#false} is VALID [2022-04-08 13:23:42,680 INFO L272 TraceCheckUtils]: 0: Hoare triple {38#true} call ULTIMATE.init(); {47#(and (= |#NULL.offset| |old(#NULL.offset)|) (= |old(#NULL.base)| |#NULL.base|))} is VALID [2022-04-08 13:23:42,680 INFO L290 TraceCheckUtils]: 1: Hoare triple {47#(and (= |#NULL.offset| |old(#NULL.offset)|) (= |old(#NULL.base)| |#NULL.base|))} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {38#true} is VALID [2022-04-08 13:23:42,680 INFO L290 TraceCheckUtils]: 2: Hoare triple {38#true} assume true; {38#true} is VALID [2022-04-08 13:23:42,681 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {38#true} {38#true} #94#return; {38#true} is VALID [2022-04-08 13:23:42,681 INFO L272 TraceCheckUtils]: 4: Hoare triple {38#true} call #t~ret5 := main(); {38#true} is VALID [2022-04-08 13:23:42,681 INFO L290 TraceCheckUtils]: 5: Hoare triple {38#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {38#true} is VALID [2022-04-08 13:23:42,682 INFO L272 TraceCheckUtils]: 6: Hoare triple {38#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {38#true} is VALID [2022-04-08 13:23:42,682 INFO L290 TraceCheckUtils]: 7: Hoare triple {38#true} ~cond := #in~cond; {38#true} is VALID [2022-04-08 13:23:42,683 INFO L290 TraceCheckUtils]: 8: Hoare triple {38#true} assume 0 == ~cond;assume false; {39#false} is VALID [2022-04-08 13:23:42,683 INFO L290 TraceCheckUtils]: 9: Hoare triple {39#false} assume true; {39#false} is VALID [2022-04-08 13:23:42,684 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {39#false} {38#true} #78#return; {39#false} is VALID [2022-04-08 13:23:42,684 INFO L290 TraceCheckUtils]: 11: Hoare triple {39#false} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {39#false} is VALID [2022-04-08 13:23:42,684 INFO L290 TraceCheckUtils]: 12: Hoare triple {39#false} assume !false; {39#false} is VALID [2022-04-08 13:23:42,684 INFO L272 TraceCheckUtils]: 13: Hoare triple {39#false} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {39#false} is VALID [2022-04-08 13:23:42,684 INFO L290 TraceCheckUtils]: 14: Hoare triple {39#false} ~cond := #in~cond; {39#false} is VALID [2022-04-08 13:23:42,685 INFO L290 TraceCheckUtils]: 15: Hoare triple {39#false} assume 0 == ~cond; {39#false} is VALID [2022-04-08 13:23:42,685 INFO L290 TraceCheckUtils]: 16: Hoare triple {39#false} assume !false; {39#false} is VALID [2022-04-08 13:23:42,685 INFO L134 CoverageAnalysis]: Checked inductivity of 0 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2022-04-08 13:23:42,686 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-08 13:23:42,686 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1608735335] [2022-04-08 13:23:42,687 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [1608735335] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:23:42,687 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:23:42,687 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [3] imperfect sequences [] total 3 [2022-04-08 13:23:42,689 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-08 13:23:42,690 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [1810144383] [2022-04-08 13:23:42,690 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [1810144383] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:23:42,690 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:23:42,690 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [3] imperfect sequences [] total 3 [2022-04-08 13:23:42,691 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [275039828] [2022-04-08 13:23:42,691 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-08 13:23:42,696 INFO L78 Accepts]: Start accepts. Automaton has has 3 states, 3 states have (on average 3.6666666666666665) internal successors, (11), 2 states have internal predecessors, (11), 2 states have call successors, (4), 3 states have call predecessors, (4), 2 states have return successors, (2), 2 states have call predecessors, (2), 1 states have call successors, (2) Word has length 17 [2022-04-08 13:23:42,698 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-08 13:23:42,700 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 3 states, 3 states have (on average 3.6666666666666665) internal successors, (11), 2 states have internal predecessors, (11), 2 states have call successors, (4), 3 states have call predecessors, (4), 2 states have return successors, (2), 2 states have call predecessors, (2), 1 states have call successors, (2) [2022-04-08 13:23:42,726 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 17 edges. 17 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:23:42,726 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 3 states [2022-04-08 13:23:42,727 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-08 13:23:42,747 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 3 interpolants. [2022-04-08 13:23:42,748 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=3, Invalid=3, Unknown=0, NotChecked=0, Total=6 [2022-04-08 13:23:42,750 INFO L87 Difference]: Start difference. First operand has 35 states, 19 states have (on average 1.5263157894736843) internal successors, (29), 20 states have internal predecessors, (29), 10 states have call successors, (10), 4 states have call predecessors, (10), 4 states have return successors, (10), 10 states have call predecessors, (10), 10 states have call successors, (10) Second operand has 3 states, 3 states have (on average 3.6666666666666665) internal successors, (11), 2 states have internal predecessors, (11), 2 states have call successors, (4), 3 states have call predecessors, (4), 2 states have return successors, (2), 2 states have call predecessors, (2), 1 states have call successors, (2) [2022-04-08 13:23:42,913 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:23:42,913 INFO L93 Difference]: Finished difference Result 61 states and 95 transitions. [2022-04-08 13:23:42,913 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 3 states. [2022-04-08 13:23:42,914 INFO L78 Accepts]: Start accepts. Automaton has has 3 states, 3 states have (on average 3.6666666666666665) internal successors, (11), 2 states have internal predecessors, (11), 2 states have call successors, (4), 3 states have call predecessors, (4), 2 states have return successors, (2), 2 states have call predecessors, (2), 1 states have call successors, (2) Word has length 17 [2022-04-08 13:23:42,914 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-08 13:23:42,915 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 3 states, 3 states have (on average 3.6666666666666665) internal successors, (11), 2 states have internal predecessors, (11), 2 states have call successors, (4), 3 states have call predecessors, (4), 2 states have return successors, (2), 2 states have call predecessors, (2), 1 states have call successors, (2) [2022-04-08 13:23:42,924 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 3 states to 3 states and 95 transitions. [2022-04-08 13:23:42,924 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 3 states, 3 states have (on average 3.6666666666666665) internal successors, (11), 2 states have internal predecessors, (11), 2 states have call successors, (4), 3 states have call predecessors, (4), 2 states have return successors, (2), 2 states have call predecessors, (2), 1 states have call successors, (2) [2022-04-08 13:23:42,932 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 3 states to 3 states and 95 transitions. [2022-04-08 13:23:42,933 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 3 states and 95 transitions. [2022-04-08 13:23:43,020 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 95 edges. 95 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:23:43,026 INFO L225 Difference]: With dead ends: 61 [2022-04-08 13:23:43,026 INFO L226 Difference]: Without dead ends: 30 [2022-04-08 13:23:43,029 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 7 GetRequests, 6 SyntacticMatches, 0 SemanticMatches, 1 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=3, Invalid=3, Unknown=0, NotChecked=0, Total=6 [2022-04-08 13:23:43,031 INFO L913 BasicCegarLoop]: 35 mSDtfsCounter, 20 mSDsluCounter, 3 mSDsCounter, 0 mSdLazyCounter, 10 mSolverCounterSat, 9 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.0s Time, 0 mProtectedPredicate, 0 mProtectedAction, 28 SdHoareTripleChecker+Valid, 38 SdHoareTripleChecker+Invalid, 19 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 9 IncrementalHoareTripleChecker+Valid, 10 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.0s IncrementalHoareTripleChecker+Time [2022-04-08 13:23:43,031 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [28 Valid, 38 Invalid, 19 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [9 Valid, 10 Invalid, 0 Unknown, 0 Unchecked, 0.0s Time] [2022-04-08 13:23:43,042 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 30 states. [2022-04-08 13:23:43,055 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 30 to 30. [2022-04-08 13:23:43,055 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-08 13:23:43,055 INFO L82 GeneralOperation]: Start isEquivalent. First operand 30 states. Second operand has 30 states, 16 states have (on average 1.25) internal successors, (20), 17 states have internal predecessors, (20), 10 states have call successors, (10), 4 states have call predecessors, (10), 3 states have return successors, (8), 8 states have call predecessors, (8), 8 states have call successors, (8) [2022-04-08 13:23:43,056 INFO L74 IsIncluded]: Start isIncluded. First operand 30 states. Second operand has 30 states, 16 states have (on average 1.25) internal successors, (20), 17 states have internal predecessors, (20), 10 states have call successors, (10), 4 states have call predecessors, (10), 3 states have return successors, (8), 8 states have call predecessors, (8), 8 states have call successors, (8) [2022-04-08 13:23:43,056 INFO L87 Difference]: Start difference. First operand 30 states. Second operand has 30 states, 16 states have (on average 1.25) internal successors, (20), 17 states have internal predecessors, (20), 10 states have call successors, (10), 4 states have call predecessors, (10), 3 states have return successors, (8), 8 states have call predecessors, (8), 8 states have call successors, (8) [2022-04-08 13:23:43,081 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:23:43,082 INFO L93 Difference]: Finished difference Result 30 states and 38 transitions. [2022-04-08 13:23:43,082 INFO L276 IsEmpty]: Start isEmpty. Operand 30 states and 38 transitions. [2022-04-08 13:23:43,082 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:23:43,083 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:23:43,083 INFO L74 IsIncluded]: Start isIncluded. First operand has 30 states, 16 states have (on average 1.25) internal successors, (20), 17 states have internal predecessors, (20), 10 states have call successors, (10), 4 states have call predecessors, (10), 3 states have return successors, (8), 8 states have call predecessors, (8), 8 states have call successors, (8) Second operand 30 states. [2022-04-08 13:23:43,083 INFO L87 Difference]: Start difference. First operand has 30 states, 16 states have (on average 1.25) internal successors, (20), 17 states have internal predecessors, (20), 10 states have call successors, (10), 4 states have call predecessors, (10), 3 states have return successors, (8), 8 states have call predecessors, (8), 8 states have call successors, (8) Second operand 30 states. [2022-04-08 13:23:43,088 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:23:43,088 INFO L93 Difference]: Finished difference Result 30 states and 38 transitions. [2022-04-08 13:23:43,088 INFO L276 IsEmpty]: Start isEmpty. Operand 30 states and 38 transitions. [2022-04-08 13:23:43,089 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:23:43,089 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:23:43,089 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-08 13:23:43,090 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-08 13:23:43,090 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 30 states, 16 states have (on average 1.25) internal successors, (20), 17 states have internal predecessors, (20), 10 states have call successors, (10), 4 states have call predecessors, (10), 3 states have return successors, (8), 8 states have call predecessors, (8), 8 states have call successors, (8) [2022-04-08 13:23:43,094 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 30 states to 30 states and 38 transitions. [2022-04-08 13:23:43,095 INFO L78 Accepts]: Start accepts. Automaton has 30 states and 38 transitions. Word has length 17 [2022-04-08 13:23:43,095 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-08 13:23:43,095 INFO L478 AbstractCegarLoop]: Abstraction has 30 states and 38 transitions. [2022-04-08 13:23:43,095 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 3 states, 3 states have (on average 3.6666666666666665) internal successors, (11), 2 states have internal predecessors, (11), 2 states have call successors, (4), 3 states have call predecessors, (4), 2 states have return successors, (2), 2 states have call predecessors, (2), 1 states have call successors, (2) [2022-04-08 13:23:43,095 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 30 states and 38 transitions. [2022-04-08 13:23:43,132 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 38 edges. 38 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:23:43,132 INFO L276 IsEmpty]: Start isEmpty. Operand 30 states and 38 transitions. [2022-04-08 13:23:43,133 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 18 [2022-04-08 13:23:43,133 INFO L491 BasicCegarLoop]: Found error trace [2022-04-08 13:23:43,133 INFO L499 BasicCegarLoop]: trace histogram [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-08 13:23:43,133 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable0 [2022-04-08 13:23:43,133 INFO L403 AbstractCegarLoop]: === Iteration 2 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-08 13:23:43,134 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-08 13:23:43,134 INFO L85 PathProgramCache]: Analyzing trace with hash -297772535, now seen corresponding path program 1 times [2022-04-08 13:23:43,134 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-08 13:23:43,134 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [1094062947] [2022-04-08 13:23:43,135 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-08 13:23:43,135 INFO L85 PathProgramCache]: Analyzing trace with hash -297772535, now seen corresponding path program 2 times [2022-04-08 13:23:43,135 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-08 13:23:43,135 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1915930898] [2022-04-08 13:23:43,135 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-08 13:23:43,135 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-08 13:23:43,150 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:23:43,190 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 0 [2022-04-08 13:23:43,193 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:23:43,198 INFO L290 TraceCheckUtils]: 0: Hoare triple {304#(and (= |#NULL.offset| |old(#NULL.offset)|) (= |old(#NULL.base)| |#NULL.base|))} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {292#true} is VALID [2022-04-08 13:23:43,198 INFO L290 TraceCheckUtils]: 1: Hoare triple {292#true} assume true; {292#true} is VALID [2022-04-08 13:23:43,198 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {292#true} {292#true} #94#return; {292#true} is VALID [2022-04-08 13:23:43,198 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 6 [2022-04-08 13:23:43,211 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:23:43,215 INFO L290 TraceCheckUtils]: 0: Hoare triple {292#true} ~cond := #in~cond; {292#true} is VALID [2022-04-08 13:23:43,215 INFO L290 TraceCheckUtils]: 1: Hoare triple {292#true} assume !(0 == ~cond); {292#true} is VALID [2022-04-08 13:23:43,215 INFO L290 TraceCheckUtils]: 2: Hoare triple {292#true} assume true; {292#true} is VALID [2022-04-08 13:23:43,215 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {292#true} {292#true} #78#return; {292#true} is VALID [2022-04-08 13:23:43,216 INFO L272 TraceCheckUtils]: 0: Hoare triple {292#true} call ULTIMATE.init(); {304#(and (= |#NULL.offset| |old(#NULL.offset)|) (= |old(#NULL.base)| |#NULL.base|))} is VALID [2022-04-08 13:23:43,216 INFO L290 TraceCheckUtils]: 1: Hoare triple {304#(and (= |#NULL.offset| |old(#NULL.offset)|) (= |old(#NULL.base)| |#NULL.base|))} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {292#true} is VALID [2022-04-08 13:23:43,216 INFO L290 TraceCheckUtils]: 2: Hoare triple {292#true} assume true; {292#true} is VALID [2022-04-08 13:23:43,216 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {292#true} {292#true} #94#return; {292#true} is VALID [2022-04-08 13:23:43,216 INFO L272 TraceCheckUtils]: 4: Hoare triple {292#true} call #t~ret5 := main(); {292#true} is VALID [2022-04-08 13:23:43,217 INFO L290 TraceCheckUtils]: 5: Hoare triple {292#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {292#true} is VALID [2022-04-08 13:23:43,217 INFO L272 TraceCheckUtils]: 6: Hoare triple {292#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {292#true} is VALID [2022-04-08 13:23:43,217 INFO L290 TraceCheckUtils]: 7: Hoare triple {292#true} ~cond := #in~cond; {292#true} is VALID [2022-04-08 13:23:43,217 INFO L290 TraceCheckUtils]: 8: Hoare triple {292#true} assume !(0 == ~cond); {292#true} is VALID [2022-04-08 13:23:43,217 INFO L290 TraceCheckUtils]: 9: Hoare triple {292#true} assume true; {292#true} is VALID [2022-04-08 13:23:43,217 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {292#true} {292#true} #78#return; {292#true} is VALID [2022-04-08 13:23:43,218 INFO L290 TraceCheckUtils]: 11: Hoare triple {292#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {301#(= main_~q~0 0)} is VALID [2022-04-08 13:23:43,218 INFO L290 TraceCheckUtils]: 12: Hoare triple {301#(= main_~q~0 0)} assume !false; {301#(= main_~q~0 0)} is VALID [2022-04-08 13:23:43,219 INFO L272 TraceCheckUtils]: 13: Hoare triple {301#(= main_~q~0 0)} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {302#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:23:43,219 INFO L290 TraceCheckUtils]: 14: Hoare triple {302#(not (= |__VERIFIER_assert_#in~cond| 0))} ~cond := #in~cond; {303#(not (= __VERIFIER_assert_~cond 0))} is VALID [2022-04-08 13:23:43,220 INFO L290 TraceCheckUtils]: 15: Hoare triple {303#(not (= __VERIFIER_assert_~cond 0))} assume 0 == ~cond; {293#false} is VALID [2022-04-08 13:23:43,220 INFO L290 TraceCheckUtils]: 16: Hoare triple {293#false} assume !false; {293#false} is VALID [2022-04-08 13:23:43,220 INFO L134 CoverageAnalysis]: Checked inductivity of 0 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2022-04-08 13:23:43,220 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-08 13:23:43,220 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1915930898] [2022-04-08 13:23:43,220 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [1915930898] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:23:43,220 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:23:43,221 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [6] imperfect sequences [] total 6 [2022-04-08 13:23:43,221 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-08 13:23:43,221 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [1094062947] [2022-04-08 13:23:43,221 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [1094062947] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:23:43,221 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:23:43,221 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [6] imperfect sequences [] total 6 [2022-04-08 13:23:43,221 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1986480199] [2022-04-08 13:23:43,221 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-08 13:23:43,222 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 1.8333333333333333) internal successors, (11), 4 states have internal predecessors, (11), 2 states have call successors, (4), 3 states have call predecessors, (4), 1 states have return successors, (2), 1 states have call predecessors, (2), 1 states have call successors, (2) Word has length 17 [2022-04-08 13:23:43,222 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-08 13:23:43,222 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 6 states, 6 states have (on average 1.8333333333333333) internal successors, (11), 4 states have internal predecessors, (11), 2 states have call successors, (4), 3 states have call predecessors, (4), 1 states have return successors, (2), 1 states have call predecessors, (2), 1 states have call successors, (2) [2022-04-08 13:23:43,234 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 17 edges. 17 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:23:43,234 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 6 states [2022-04-08 13:23:43,234 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-08 13:23:43,235 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 6 interpolants. [2022-04-08 13:23:43,235 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=9, Invalid=21, Unknown=0, NotChecked=0, Total=30 [2022-04-08 13:23:43,235 INFO L87 Difference]: Start difference. First operand 30 states and 38 transitions. Second operand has 6 states, 6 states have (on average 1.8333333333333333) internal successors, (11), 4 states have internal predecessors, (11), 2 states have call successors, (4), 3 states have call predecessors, (4), 1 states have return successors, (2), 1 states have call predecessors, (2), 1 states have call successors, (2) [2022-04-08 13:23:43,629 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:23:43,629 INFO L93 Difference]: Finished difference Result 43 states and 55 transitions. [2022-04-08 13:23:43,629 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 7 states. [2022-04-08 13:23:43,630 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 1.8333333333333333) internal successors, (11), 4 states have internal predecessors, (11), 2 states have call successors, (4), 3 states have call predecessors, (4), 1 states have return successors, (2), 1 states have call predecessors, (2), 1 states have call successors, (2) Word has length 17 [2022-04-08 13:23:43,630 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-08 13:23:43,630 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 1.8333333333333333) internal successors, (11), 4 states have internal predecessors, (11), 2 states have call successors, (4), 3 states have call predecessors, (4), 1 states have return successors, (2), 1 states have call predecessors, (2), 1 states have call successors, (2) [2022-04-08 13:23:43,647 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 7 states to 7 states and 55 transitions. [2022-04-08 13:23:43,648 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 1.8333333333333333) internal successors, (11), 4 states have internal predecessors, (11), 2 states have call successors, (4), 3 states have call predecessors, (4), 1 states have return successors, (2), 1 states have call predecessors, (2), 1 states have call successors, (2) [2022-04-08 13:23:43,650 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 7 states to 7 states and 55 transitions. [2022-04-08 13:23:43,650 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 7 states and 55 transitions. [2022-04-08 13:23:43,735 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 55 edges. 55 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:23:43,741 INFO L225 Difference]: With dead ends: 43 [2022-04-08 13:23:43,741 INFO L226 Difference]: Without dead ends: 41 [2022-04-08 13:23:43,742 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 13 GetRequests, 5 SyntacticMatches, 0 SemanticMatches, 8 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 5 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=28, Invalid=62, Unknown=0, NotChecked=0, Total=90 [2022-04-08 13:23:43,745 INFO L913 BasicCegarLoop]: 28 mSDtfsCounter, 37 mSDsluCounter, 17 mSDsCounter, 0 mSdLazyCounter, 109 mSolverCounterSat, 27 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.1s Time, 0 mProtectedPredicate, 0 mProtectedAction, 41 SdHoareTripleChecker+Valid, 45 SdHoareTripleChecker+Invalid, 136 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 27 IncrementalHoareTripleChecker+Valid, 109 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.2s IncrementalHoareTripleChecker+Time [2022-04-08 13:23:43,747 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [41 Valid, 45 Invalid, 136 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [27 Valid, 109 Invalid, 0 Unknown, 0 Unchecked, 0.2s Time] [2022-04-08 13:23:43,749 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 41 states. [2022-04-08 13:23:43,761 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 41 to 34. [2022-04-08 13:23:43,761 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-08 13:23:43,762 INFO L82 GeneralOperation]: Start isEquivalent. First operand 41 states. Second operand has 34 states, 19 states have (on average 1.2105263157894737) internal successors, (23), 20 states have internal predecessors, (23), 10 states have call successors, (10), 5 states have call predecessors, (10), 4 states have return successors, (8), 8 states have call predecessors, (8), 8 states have call successors, (8) [2022-04-08 13:23:43,763 INFO L74 IsIncluded]: Start isIncluded. First operand 41 states. Second operand has 34 states, 19 states have (on average 1.2105263157894737) internal successors, (23), 20 states have internal predecessors, (23), 10 states have call successors, (10), 5 states have call predecessors, (10), 4 states have return successors, (8), 8 states have call predecessors, (8), 8 states have call successors, (8) [2022-04-08 13:23:43,764 INFO L87 Difference]: Start difference. First operand 41 states. Second operand has 34 states, 19 states have (on average 1.2105263157894737) internal successors, (23), 20 states have internal predecessors, (23), 10 states have call successors, (10), 5 states have call predecessors, (10), 4 states have return successors, (8), 8 states have call predecessors, (8), 8 states have call successors, (8) [2022-04-08 13:23:43,771 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:23:43,771 INFO L93 Difference]: Finished difference Result 41 states and 53 transitions. [2022-04-08 13:23:43,771 INFO L276 IsEmpty]: Start isEmpty. Operand 41 states and 53 transitions. [2022-04-08 13:23:43,777 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:23:43,777 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:23:43,779 INFO L74 IsIncluded]: Start isIncluded. First operand has 34 states, 19 states have (on average 1.2105263157894737) internal successors, (23), 20 states have internal predecessors, (23), 10 states have call successors, (10), 5 states have call predecessors, (10), 4 states have return successors, (8), 8 states have call predecessors, (8), 8 states have call successors, (8) Second operand 41 states. [2022-04-08 13:23:43,779 INFO L87 Difference]: Start difference. First operand has 34 states, 19 states have (on average 1.2105263157894737) internal successors, (23), 20 states have internal predecessors, (23), 10 states have call successors, (10), 5 states have call predecessors, (10), 4 states have return successors, (8), 8 states have call predecessors, (8), 8 states have call successors, (8) Second operand 41 states. [2022-04-08 13:23:43,783 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:23:43,783 INFO L93 Difference]: Finished difference Result 41 states and 53 transitions. [2022-04-08 13:23:43,783 INFO L276 IsEmpty]: Start isEmpty. Operand 41 states and 53 transitions. [2022-04-08 13:23:43,783 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:23:43,783 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:23:43,783 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-08 13:23:43,784 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-08 13:23:43,784 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 34 states, 19 states have (on average 1.2105263157894737) internal successors, (23), 20 states have internal predecessors, (23), 10 states have call successors, (10), 5 states have call predecessors, (10), 4 states have return successors, (8), 8 states have call predecessors, (8), 8 states have call successors, (8) [2022-04-08 13:23:43,785 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 34 states to 34 states and 41 transitions. [2022-04-08 13:23:43,785 INFO L78 Accepts]: Start accepts. Automaton has 34 states and 41 transitions. Word has length 17 [2022-04-08 13:23:43,786 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-08 13:23:43,786 INFO L478 AbstractCegarLoop]: Abstraction has 34 states and 41 transitions. [2022-04-08 13:23:43,786 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 6 states, 6 states have (on average 1.8333333333333333) internal successors, (11), 4 states have internal predecessors, (11), 2 states have call successors, (4), 3 states have call predecessors, (4), 1 states have return successors, (2), 1 states have call predecessors, (2), 1 states have call successors, (2) [2022-04-08 13:23:43,786 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 34 states and 41 transitions. [2022-04-08 13:23:43,835 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 41 edges. 41 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:23:43,836 INFO L276 IsEmpty]: Start isEmpty. Operand 34 states and 41 transitions. [2022-04-08 13:23:43,837 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 23 [2022-04-08 13:23:43,837 INFO L491 BasicCegarLoop]: Found error trace [2022-04-08 13:23:43,837 INFO L499 BasicCegarLoop]: trace histogram [2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-08 13:23:43,838 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable1 [2022-04-08 13:23:43,838 INFO L403 AbstractCegarLoop]: === Iteration 3 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-08 13:23:43,841 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-08 13:23:43,843 INFO L85 PathProgramCache]: Analyzing trace with hash -1294462534, now seen corresponding path program 1 times [2022-04-08 13:23:43,843 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-08 13:23:43,848 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [1049806326] [2022-04-08 13:23:43,848 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-08 13:23:43,849 INFO L85 PathProgramCache]: Analyzing trace with hash -1294462534, now seen corresponding path program 2 times [2022-04-08 13:23:43,849 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-08 13:23:43,849 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1576711416] [2022-04-08 13:23:43,849 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-08 13:23:43,849 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-08 13:23:43,867 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:23:43,915 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 0 [2022-04-08 13:23:43,916 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:23:43,920 INFO L290 TraceCheckUtils]: 0: Hoare triple {567#(and (= |#NULL.offset| |old(#NULL.offset)|) (= |old(#NULL.base)| |#NULL.base|))} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {551#true} is VALID [2022-04-08 13:23:43,921 INFO L290 TraceCheckUtils]: 1: Hoare triple {551#true} assume true; {551#true} is VALID [2022-04-08 13:23:43,921 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {551#true} {551#true} #94#return; {551#true} is VALID [2022-04-08 13:23:43,921 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 6 [2022-04-08 13:23:43,922 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:23:43,925 INFO L290 TraceCheckUtils]: 0: Hoare triple {551#true} ~cond := #in~cond; {551#true} is VALID [2022-04-08 13:23:43,925 INFO L290 TraceCheckUtils]: 1: Hoare triple {551#true} assume !(0 == ~cond); {551#true} is VALID [2022-04-08 13:23:43,925 INFO L290 TraceCheckUtils]: 2: Hoare triple {551#true} assume true; {551#true} is VALID [2022-04-08 13:23:43,925 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {551#true} {551#true} #78#return; {551#true} is VALID [2022-04-08 13:23:43,926 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 13 [2022-04-08 13:23:43,927 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:23:43,930 INFO L290 TraceCheckUtils]: 0: Hoare triple {551#true} ~cond := #in~cond; {551#true} is VALID [2022-04-08 13:23:43,930 INFO L290 TraceCheckUtils]: 1: Hoare triple {551#true} assume !(0 == ~cond); {551#true} is VALID [2022-04-08 13:23:43,931 INFO L290 TraceCheckUtils]: 2: Hoare triple {551#true} assume true; {551#true} is VALID [2022-04-08 13:23:43,931 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {551#true} {560#(= main_~A~0 main_~r~0)} #80#return; {560#(= main_~A~0 main_~r~0)} is VALID [2022-04-08 13:23:43,932 INFO L272 TraceCheckUtils]: 0: Hoare triple {551#true} call ULTIMATE.init(); {567#(and (= |#NULL.offset| |old(#NULL.offset)|) (= |old(#NULL.base)| |#NULL.base|))} is VALID [2022-04-08 13:23:43,932 INFO L290 TraceCheckUtils]: 1: Hoare triple {567#(and (= |#NULL.offset| |old(#NULL.offset)|) (= |old(#NULL.base)| |#NULL.base|))} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {551#true} is VALID [2022-04-08 13:23:43,932 INFO L290 TraceCheckUtils]: 2: Hoare triple {551#true} assume true; {551#true} is VALID [2022-04-08 13:23:43,932 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {551#true} {551#true} #94#return; {551#true} is VALID [2022-04-08 13:23:43,932 INFO L272 TraceCheckUtils]: 4: Hoare triple {551#true} call #t~ret5 := main(); {551#true} is VALID [2022-04-08 13:23:43,933 INFO L290 TraceCheckUtils]: 5: Hoare triple {551#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {551#true} is VALID [2022-04-08 13:23:43,933 INFO L272 TraceCheckUtils]: 6: Hoare triple {551#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {551#true} is VALID [2022-04-08 13:23:43,933 INFO L290 TraceCheckUtils]: 7: Hoare triple {551#true} ~cond := #in~cond; {551#true} is VALID [2022-04-08 13:23:43,933 INFO L290 TraceCheckUtils]: 8: Hoare triple {551#true} assume !(0 == ~cond); {551#true} is VALID [2022-04-08 13:23:43,933 INFO L290 TraceCheckUtils]: 9: Hoare triple {551#true} assume true; {551#true} is VALID [2022-04-08 13:23:43,933 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {551#true} {551#true} #78#return; {551#true} is VALID [2022-04-08 13:23:43,934 INFO L290 TraceCheckUtils]: 11: Hoare triple {551#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {560#(= main_~A~0 main_~r~0)} is VALID [2022-04-08 13:23:43,934 INFO L290 TraceCheckUtils]: 12: Hoare triple {560#(= main_~A~0 main_~r~0)} assume !false; {560#(= main_~A~0 main_~r~0)} is VALID [2022-04-08 13:23:43,934 INFO L272 TraceCheckUtils]: 13: Hoare triple {560#(= main_~A~0 main_~r~0)} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {551#true} is VALID [2022-04-08 13:23:43,934 INFO L290 TraceCheckUtils]: 14: Hoare triple {551#true} ~cond := #in~cond; {551#true} is VALID [2022-04-08 13:23:43,934 INFO L290 TraceCheckUtils]: 15: Hoare triple {551#true} assume !(0 == ~cond); {551#true} is VALID [2022-04-08 13:23:43,935 INFO L290 TraceCheckUtils]: 16: Hoare triple {551#true} assume true; {551#true} is VALID [2022-04-08 13:23:43,935 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {551#true} {560#(= main_~A~0 main_~r~0)} #80#return; {560#(= main_~A~0 main_~r~0)} is VALID [2022-04-08 13:23:43,936 INFO L272 TraceCheckUtils]: 18: Hoare triple {560#(= main_~A~0 main_~r~0)} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {565#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:23:43,936 INFO L290 TraceCheckUtils]: 19: Hoare triple {565#(not (= |__VERIFIER_assert_#in~cond| 0))} ~cond := #in~cond; {566#(not (= __VERIFIER_assert_~cond 0))} is VALID [2022-04-08 13:23:43,936 INFO L290 TraceCheckUtils]: 20: Hoare triple {566#(not (= __VERIFIER_assert_~cond 0))} assume 0 == ~cond; {552#false} is VALID [2022-04-08 13:23:43,937 INFO L290 TraceCheckUtils]: 21: Hoare triple {552#false} assume !false; {552#false} is VALID [2022-04-08 13:23:43,937 INFO L134 CoverageAnalysis]: Checked inductivity of 2 backedges. 2 proven. 0 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2022-04-08 13:23:43,937 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-08 13:23:43,937 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1576711416] [2022-04-08 13:23:43,937 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [1576711416] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:23:43,937 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:23:43,938 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [6] imperfect sequences [] total 6 [2022-04-08 13:23:43,938 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-08 13:23:43,938 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [1049806326] [2022-04-08 13:23:43,938 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [1049806326] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:23:43,938 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:23:43,938 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [6] imperfect sequences [] total 6 [2022-04-08 13:23:43,938 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [2008742013] [2022-04-08 13:23:43,938 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-08 13:23:43,939 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 2.3333333333333335) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (5), 3 states have call predecessors, (5), 1 states have return successors, (3), 2 states have call predecessors, (3), 2 states have call successors, (3) Word has length 22 [2022-04-08 13:23:43,939 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-08 13:23:43,939 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 6 states, 6 states have (on average 2.3333333333333335) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (5), 3 states have call predecessors, (5), 1 states have return successors, (3), 2 states have call predecessors, (3), 2 states have call successors, (3) [2022-04-08 13:23:43,952 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 22 edges. 22 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:23:43,952 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 6 states [2022-04-08 13:23:43,952 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-08 13:23:43,952 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 6 interpolants. [2022-04-08 13:23:43,952 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=9, Invalid=21, Unknown=0, NotChecked=0, Total=30 [2022-04-08 13:23:43,953 INFO L87 Difference]: Start difference. First operand 34 states and 41 transitions. Second operand has 6 states, 6 states have (on average 2.3333333333333335) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (5), 3 states have call predecessors, (5), 1 states have return successors, (3), 2 states have call predecessors, (3), 2 states have call successors, (3) [2022-04-08 13:23:44,248 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:23:44,248 INFO L93 Difference]: Finished difference Result 47 states and 58 transitions. [2022-04-08 13:23:44,249 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 7 states. [2022-04-08 13:23:44,249 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 2.3333333333333335) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (5), 3 states have call predecessors, (5), 1 states have return successors, (3), 2 states have call predecessors, (3), 2 states have call successors, (3) Word has length 22 [2022-04-08 13:23:44,249 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-08 13:23:44,249 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 2.3333333333333335) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (5), 3 states have call predecessors, (5), 1 states have return successors, (3), 2 states have call predecessors, (3), 2 states have call successors, (3) [2022-04-08 13:23:44,251 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 7 states to 7 states and 55 transitions. [2022-04-08 13:23:44,251 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 2.3333333333333335) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (5), 3 states have call predecessors, (5), 1 states have return successors, (3), 2 states have call predecessors, (3), 2 states have call successors, (3) [2022-04-08 13:23:44,252 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 7 states to 7 states and 55 transitions. [2022-04-08 13:23:44,252 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 7 states and 55 transitions. [2022-04-08 13:23:44,295 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 55 edges. 55 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:23:44,296 INFO L225 Difference]: With dead ends: 47 [2022-04-08 13:23:44,297 INFO L226 Difference]: Without dead ends: 45 [2022-04-08 13:23:44,297 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 15 GetRequests, 7 SyntacticMatches, 0 SemanticMatches, 8 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 4 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=28, Invalid=62, Unknown=0, NotChecked=0, Total=90 [2022-04-08 13:23:44,298 INFO L913 BasicCegarLoop]: 28 mSDtfsCounter, 32 mSDsluCounter, 17 mSDsCounter, 0 mSdLazyCounter, 115 mSolverCounterSat, 26 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.1s Time, 0 mProtectedPredicate, 0 mProtectedAction, 36 SdHoareTripleChecker+Valid, 45 SdHoareTripleChecker+Invalid, 141 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 26 IncrementalHoareTripleChecker+Valid, 115 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.1s IncrementalHoareTripleChecker+Time [2022-04-08 13:23:44,298 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [36 Valid, 45 Invalid, 141 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [26 Valid, 115 Invalid, 0 Unknown, 0 Unchecked, 0.1s Time] [2022-04-08 13:23:44,298 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 45 states. [2022-04-08 13:23:44,302 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 45 to 38. [2022-04-08 13:23:44,303 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-08 13:23:44,303 INFO L82 GeneralOperation]: Start isEquivalent. First operand 45 states. Second operand has 38 states, 22 states have (on average 1.1818181818181819) internal successors, (26), 23 states have internal predecessors, (26), 10 states have call successors, (10), 6 states have call predecessors, (10), 5 states have return successors, (8), 8 states have call predecessors, (8), 8 states have call successors, (8) [2022-04-08 13:23:44,303 INFO L74 IsIncluded]: Start isIncluded. First operand 45 states. Second operand has 38 states, 22 states have (on average 1.1818181818181819) internal successors, (26), 23 states have internal predecessors, (26), 10 states have call successors, (10), 6 states have call predecessors, (10), 5 states have return successors, (8), 8 states have call predecessors, (8), 8 states have call successors, (8) [2022-04-08 13:23:44,303 INFO L87 Difference]: Start difference. First operand 45 states. Second operand has 38 states, 22 states have (on average 1.1818181818181819) internal successors, (26), 23 states have internal predecessors, (26), 10 states have call successors, (10), 6 states have call predecessors, (10), 5 states have return successors, (8), 8 states have call predecessors, (8), 8 states have call successors, (8) [2022-04-08 13:23:44,305 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:23:44,305 INFO L93 Difference]: Finished difference Result 45 states and 56 transitions. [2022-04-08 13:23:44,305 INFO L276 IsEmpty]: Start isEmpty. Operand 45 states and 56 transitions. [2022-04-08 13:23:44,305 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:23:44,305 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:23:44,306 INFO L74 IsIncluded]: Start isIncluded. First operand has 38 states, 22 states have (on average 1.1818181818181819) internal successors, (26), 23 states have internal predecessors, (26), 10 states have call successors, (10), 6 states have call predecessors, (10), 5 states have return successors, (8), 8 states have call predecessors, (8), 8 states have call successors, (8) Second operand 45 states. [2022-04-08 13:23:44,306 INFO L87 Difference]: Start difference. First operand has 38 states, 22 states have (on average 1.1818181818181819) internal successors, (26), 23 states have internal predecessors, (26), 10 states have call successors, (10), 6 states have call predecessors, (10), 5 states have return successors, (8), 8 states have call predecessors, (8), 8 states have call successors, (8) Second operand 45 states. [2022-04-08 13:23:44,308 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:23:44,308 INFO L93 Difference]: Finished difference Result 45 states and 56 transitions. [2022-04-08 13:23:44,308 INFO L276 IsEmpty]: Start isEmpty. Operand 45 states and 56 transitions. [2022-04-08 13:23:44,308 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:23:44,308 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:23:44,308 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-08 13:23:44,308 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-08 13:23:44,309 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 38 states, 22 states have (on average 1.1818181818181819) internal successors, (26), 23 states have internal predecessors, (26), 10 states have call successors, (10), 6 states have call predecessors, (10), 5 states have return successors, (8), 8 states have call predecessors, (8), 8 states have call successors, (8) [2022-04-08 13:23:44,310 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 38 states to 38 states and 44 transitions. [2022-04-08 13:23:44,310 INFO L78 Accepts]: Start accepts. Automaton has 38 states and 44 transitions. Word has length 22 [2022-04-08 13:23:44,310 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-08 13:23:44,310 INFO L478 AbstractCegarLoop]: Abstraction has 38 states and 44 transitions. [2022-04-08 13:23:44,310 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 6 states, 6 states have (on average 2.3333333333333335) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (5), 3 states have call predecessors, (5), 1 states have return successors, (3), 2 states have call predecessors, (3), 2 states have call successors, (3) [2022-04-08 13:23:44,310 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 38 states and 44 transitions. [2022-04-08 13:23:44,352 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 44 edges. 44 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:23:44,352 INFO L276 IsEmpty]: Start isEmpty. Operand 38 states and 44 transitions. [2022-04-08 13:23:44,352 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 28 [2022-04-08 13:23:44,352 INFO L491 BasicCegarLoop]: Found error trace [2022-04-08 13:23:44,352 INFO L499 BasicCegarLoop]: trace histogram [3, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-08 13:23:44,353 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable2 [2022-04-08 13:23:44,354 INFO L403 AbstractCegarLoop]: === Iteration 4 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-08 13:23:44,355 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-08 13:23:44,355 INFO L85 PathProgramCache]: Analyzing trace with hash -1449027479, now seen corresponding path program 1 times [2022-04-08 13:23:44,355 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-08 13:23:44,358 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [1543442463] [2022-04-08 13:23:44,364 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-08 13:23:44,365 INFO L85 PathProgramCache]: Analyzing trace with hash -1449027479, now seen corresponding path program 2 times [2022-04-08 13:23:44,365 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-08 13:23:44,365 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [90755635] [2022-04-08 13:23:44,365 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-08 13:23:44,365 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-08 13:23:44,380 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-08 13:23:44,380 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1483853490] [2022-04-08 13:23:44,380 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-08 13:23:44,380 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:23:44,380 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-08 13:23:44,385 INFO L229 MonitoredProcess]: Starting monitored process 2 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-08 13:23:44,389 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (2)] Waiting until timeout for monitored process [2022-04-08 13:23:44,422 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-08 13:23:44,423 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-08 13:23:44,424 INFO L263 TraceCheckSpWp]: Trace formula consists of 90 conjuncts, 9 conjunts are in the unsatisfiable core [2022-04-08 13:23:44,457 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:23:44,460 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-08 13:23:44,662 INFO L272 TraceCheckUtils]: 0: Hoare triple {838#true} call ULTIMATE.init(); {838#true} is VALID [2022-04-08 13:23:44,662 INFO L290 TraceCheckUtils]: 1: Hoare triple {838#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {838#true} is VALID [2022-04-08 13:23:44,662 INFO L290 TraceCheckUtils]: 2: Hoare triple {838#true} assume true; {838#true} is VALID [2022-04-08 13:23:44,663 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {838#true} {838#true} #94#return; {838#true} is VALID [2022-04-08 13:23:44,663 INFO L272 TraceCheckUtils]: 4: Hoare triple {838#true} call #t~ret5 := main(); {838#true} is VALID [2022-04-08 13:23:44,663 INFO L290 TraceCheckUtils]: 5: Hoare triple {838#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {838#true} is VALID [2022-04-08 13:23:44,663 INFO L272 TraceCheckUtils]: 6: Hoare triple {838#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {838#true} is VALID [2022-04-08 13:23:44,663 INFO L290 TraceCheckUtils]: 7: Hoare triple {838#true} ~cond := #in~cond; {838#true} is VALID [2022-04-08 13:23:44,663 INFO L290 TraceCheckUtils]: 8: Hoare triple {838#true} assume !(0 == ~cond); {838#true} is VALID [2022-04-08 13:23:44,663 INFO L290 TraceCheckUtils]: 9: Hoare triple {838#true} assume true; {838#true} is VALID [2022-04-08 13:23:44,663 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {838#true} {838#true} #78#return; {838#true} is VALID [2022-04-08 13:23:44,664 INFO L290 TraceCheckUtils]: 11: Hoare triple {838#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {876#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:23:44,664 INFO L290 TraceCheckUtils]: 12: Hoare triple {876#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !false; {876#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:23:44,665 INFO L272 TraceCheckUtils]: 13: Hoare triple {876#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {838#true} is VALID [2022-04-08 13:23:44,665 INFO L290 TraceCheckUtils]: 14: Hoare triple {838#true} ~cond := #in~cond; {838#true} is VALID [2022-04-08 13:23:44,665 INFO L290 TraceCheckUtils]: 15: Hoare triple {838#true} assume !(0 == ~cond); {838#true} is VALID [2022-04-08 13:23:44,665 INFO L290 TraceCheckUtils]: 16: Hoare triple {838#true} assume true; {838#true} is VALID [2022-04-08 13:23:44,666 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {838#true} {876#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #80#return; {876#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:23:44,666 INFO L272 TraceCheckUtils]: 18: Hoare triple {876#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {838#true} is VALID [2022-04-08 13:23:44,666 INFO L290 TraceCheckUtils]: 19: Hoare triple {838#true} ~cond := #in~cond; {838#true} is VALID [2022-04-08 13:23:44,666 INFO L290 TraceCheckUtils]: 20: Hoare triple {838#true} assume !(0 == ~cond); {838#true} is VALID [2022-04-08 13:23:44,666 INFO L290 TraceCheckUtils]: 21: Hoare triple {838#true} assume true; {838#true} is VALID [2022-04-08 13:23:44,667 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {838#true} {876#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #82#return; {876#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:23:44,668 INFO L272 TraceCheckUtils]: 23: Hoare triple {876#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {913#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:23:44,668 INFO L290 TraceCheckUtils]: 24: Hoare triple {913#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {917#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:23:44,668 INFO L290 TraceCheckUtils]: 25: Hoare triple {917#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {839#false} is VALID [2022-04-08 13:23:44,669 INFO L290 TraceCheckUtils]: 26: Hoare triple {839#false} assume !false; {839#false} is VALID [2022-04-08 13:23:44,669 INFO L134 CoverageAnalysis]: Checked inductivity of 8 backedges. 4 proven. 0 refuted. 0 times theorem prover too weak. 4 trivial. 0 not checked. [2022-04-08 13:23:44,669 INFO L324 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2022-04-08 13:23:44,669 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-08 13:23:44,669 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [90755635] [2022-04-08 13:23:44,669 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-08 13:23:44,669 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1483853490] [2022-04-08 13:23:44,669 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1483853490] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:23:44,669 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:23:44,670 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [] total 5 [2022-04-08 13:23:44,670 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-08 13:23:44,670 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [1543442463] [2022-04-08 13:23:44,670 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [1543442463] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:23:44,670 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:23:44,670 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [] total 5 [2022-04-08 13:23:44,670 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1655191650] [2022-04-08 13:23:44,670 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-08 13:23:44,671 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 2.8) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (6), 2 states have call predecessors, (6), 1 states have return successors, (4), 2 states have call predecessors, (4), 2 states have call successors, (4) Word has length 27 [2022-04-08 13:23:44,671 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-08 13:23:44,671 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 5 states, 5 states have (on average 2.8) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (6), 2 states have call predecessors, (6), 1 states have return successors, (4), 2 states have call predecessors, (4), 2 states have call successors, (4) [2022-04-08 13:23:44,687 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 24 edges. 24 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:23:44,687 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 5 states [2022-04-08 13:23:44,687 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-08 13:23:44,688 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 5 interpolants. [2022-04-08 13:23:44,688 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=7, Invalid=13, Unknown=0, NotChecked=0, Total=20 [2022-04-08 13:23:44,688 INFO L87 Difference]: Start difference. First operand 38 states and 44 transitions. Second operand has 5 states, 5 states have (on average 2.8) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (6), 2 states have call predecessors, (6), 1 states have return successors, (4), 2 states have call predecessors, (4), 2 states have call successors, (4) [2022-04-08 13:23:44,869 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:23:44,869 INFO L93 Difference]: Finished difference Result 66 states and 84 transitions. [2022-04-08 13:23:44,869 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 5 states. [2022-04-08 13:23:44,870 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 2.8) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (6), 2 states have call predecessors, (6), 1 states have return successors, (4), 2 states have call predecessors, (4), 2 states have call successors, (4) Word has length 27 [2022-04-08 13:23:44,870 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-08 13:23:44,870 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 2.8) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (6), 2 states have call predecessors, (6), 1 states have return successors, (4), 2 states have call predecessors, (4), 2 states have call successors, (4) [2022-04-08 13:23:44,871 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 78 transitions. [2022-04-08 13:23:44,872 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 2.8) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (6), 2 states have call predecessors, (6), 1 states have return successors, (4), 2 states have call predecessors, (4), 2 states have call successors, (4) [2022-04-08 13:23:44,873 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 78 transitions. [2022-04-08 13:23:44,873 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 5 states and 78 transitions. [2022-04-08 13:23:44,933 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 78 edges. 78 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:23:44,934 INFO L225 Difference]: With dead ends: 66 [2022-04-08 13:23:44,934 INFO L226 Difference]: Without dead ends: 52 [2022-04-08 13:23:44,934 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 27 GetRequests, 23 SyntacticMatches, 0 SemanticMatches, 4 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=11, Invalid=19, Unknown=0, NotChecked=0, Total=30 [2022-04-08 13:23:44,935 INFO L913 BasicCegarLoop]: 40 mSDtfsCounter, 8 mSDsluCounter, 88 mSDsCounter, 0 mSdLazyCounter, 47 mSolverCounterSat, 3 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.0s Time, 0 mProtectedPredicate, 0 mProtectedAction, 12 SdHoareTripleChecker+Valid, 128 SdHoareTripleChecker+Invalid, 50 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 3 IncrementalHoareTripleChecker+Valid, 47 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.0s IncrementalHoareTripleChecker+Time [2022-04-08 13:23:44,936 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [12 Valid, 128 Invalid, 50 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [3 Valid, 47 Invalid, 0 Unknown, 0 Unchecked, 0.0s Time] [2022-04-08 13:23:44,936 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 52 states. [2022-04-08 13:23:44,955 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 52 to 52. [2022-04-08 13:23:44,955 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-08 13:23:44,956 INFO L82 GeneralOperation]: Start isEquivalent. First operand 52 states. Second operand has 52 states, 29 states have (on average 1.1724137931034482) internal successors, (34), 31 states have internal predecessors, (34), 16 states have call successors, (16), 7 states have call predecessors, (16), 6 states have return successors, (13), 13 states have call predecessors, (13), 13 states have call successors, (13) [2022-04-08 13:23:44,957 INFO L74 IsIncluded]: Start isIncluded. First operand 52 states. Second operand has 52 states, 29 states have (on average 1.1724137931034482) internal successors, (34), 31 states have internal predecessors, (34), 16 states have call successors, (16), 7 states have call predecessors, (16), 6 states have return successors, (13), 13 states have call predecessors, (13), 13 states have call successors, (13) [2022-04-08 13:23:44,957 INFO L87 Difference]: Start difference. First operand 52 states. Second operand has 52 states, 29 states have (on average 1.1724137931034482) internal successors, (34), 31 states have internal predecessors, (34), 16 states have call successors, (16), 7 states have call predecessors, (16), 6 states have return successors, (13), 13 states have call predecessors, (13), 13 states have call successors, (13) [2022-04-08 13:23:44,960 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:23:44,960 INFO L93 Difference]: Finished difference Result 52 states and 63 transitions. [2022-04-08 13:23:44,961 INFO L276 IsEmpty]: Start isEmpty. Operand 52 states and 63 transitions. [2022-04-08 13:23:44,961 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:23:44,961 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:23:44,962 INFO L74 IsIncluded]: Start isIncluded. First operand has 52 states, 29 states have (on average 1.1724137931034482) internal successors, (34), 31 states have internal predecessors, (34), 16 states have call successors, (16), 7 states have call predecessors, (16), 6 states have return successors, (13), 13 states have call predecessors, (13), 13 states have call successors, (13) Second operand 52 states. [2022-04-08 13:23:44,963 INFO L87 Difference]: Start difference. First operand has 52 states, 29 states have (on average 1.1724137931034482) internal successors, (34), 31 states have internal predecessors, (34), 16 states have call successors, (16), 7 states have call predecessors, (16), 6 states have return successors, (13), 13 states have call predecessors, (13), 13 states have call successors, (13) Second operand 52 states. [2022-04-08 13:23:44,966 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:23:44,967 INFO L93 Difference]: Finished difference Result 52 states and 63 transitions. [2022-04-08 13:23:44,967 INFO L276 IsEmpty]: Start isEmpty. Operand 52 states and 63 transitions. [2022-04-08 13:23:44,967 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:23:44,967 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:23:44,967 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-08 13:23:44,967 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-08 13:23:44,967 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 52 states, 29 states have (on average 1.1724137931034482) internal successors, (34), 31 states have internal predecessors, (34), 16 states have call successors, (16), 7 states have call predecessors, (16), 6 states have return successors, (13), 13 states have call predecessors, (13), 13 states have call successors, (13) [2022-04-08 13:23:44,969 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 52 states to 52 states and 63 transitions. [2022-04-08 13:23:44,969 INFO L78 Accepts]: Start accepts. Automaton has 52 states and 63 transitions. Word has length 27 [2022-04-08 13:23:44,969 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-08 13:23:44,969 INFO L478 AbstractCegarLoop]: Abstraction has 52 states and 63 transitions. [2022-04-08 13:23:44,970 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 5 states, 5 states have (on average 2.8) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (6), 2 states have call predecessors, (6), 1 states have return successors, (4), 2 states have call predecessors, (4), 2 states have call successors, (4) [2022-04-08 13:23:44,970 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 52 states and 63 transitions. [2022-04-08 13:23:45,017 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 63 edges. 63 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:23:45,017 INFO L276 IsEmpty]: Start isEmpty. Operand 52 states and 63 transitions. [2022-04-08 13:23:45,018 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 35 [2022-04-08 13:23:45,018 INFO L491 BasicCegarLoop]: Found error trace [2022-04-08 13:23:45,018 INFO L499 BasicCegarLoop]: trace histogram [4, 3, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-08 13:23:45,057 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (2)] Forceful destruction successful, exit code 0 [2022-04-08 13:23:45,231 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable3,2 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:23:45,231 INFO L403 AbstractCegarLoop]: === Iteration 5 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-08 13:23:45,232 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-08 13:23:45,233 INFO L85 PathProgramCache]: Analyzing trace with hash 905213191, now seen corresponding path program 1 times [2022-04-08 13:23:45,233 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-08 13:23:45,233 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [270180533] [2022-04-08 13:23:45,233 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-08 13:23:45,233 INFO L85 PathProgramCache]: Analyzing trace with hash 905213191, now seen corresponding path program 2 times [2022-04-08 13:23:45,233 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-08 13:23:45,233 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [689739767] [2022-04-08 13:23:45,234 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-08 13:23:45,234 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-08 13:23:45,251 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-08 13:23:45,251 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [622645239] [2022-04-08 13:23:45,251 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-08 13:23:45,251 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:23:45,251 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-08 13:23:45,257 INFO L229 MonitoredProcess]: Starting monitored process 3 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-08 13:23:45,259 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (3)] Waiting until timeout for monitored process [2022-04-08 13:23:45,295 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-08 13:23:45,295 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-08 13:23:45,296 INFO L263 TraceCheckSpWp]: Trace formula consists of 101 conjuncts, 7 conjunts are in the unsatisfiable core [2022-04-08 13:23:45,303 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:23:45,304 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-08 13:23:45,414 INFO L272 TraceCheckUtils]: 0: Hoare triple {1265#true} call ULTIMATE.init(); {1265#true} is VALID [2022-04-08 13:23:45,414 INFO L290 TraceCheckUtils]: 1: Hoare triple {1265#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {1265#true} is VALID [2022-04-08 13:23:45,414 INFO L290 TraceCheckUtils]: 2: Hoare triple {1265#true} assume true; {1265#true} is VALID [2022-04-08 13:23:45,414 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {1265#true} {1265#true} #94#return; {1265#true} is VALID [2022-04-08 13:23:45,414 INFO L272 TraceCheckUtils]: 4: Hoare triple {1265#true} call #t~ret5 := main(); {1265#true} is VALID [2022-04-08 13:23:45,414 INFO L290 TraceCheckUtils]: 5: Hoare triple {1265#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {1265#true} is VALID [2022-04-08 13:23:45,414 INFO L272 TraceCheckUtils]: 6: Hoare triple {1265#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {1265#true} is VALID [2022-04-08 13:23:45,414 INFO L290 TraceCheckUtils]: 7: Hoare triple {1265#true} ~cond := #in~cond; {1265#true} is VALID [2022-04-08 13:23:45,415 INFO L290 TraceCheckUtils]: 8: Hoare triple {1265#true} assume !(0 == ~cond); {1265#true} is VALID [2022-04-08 13:23:45,415 INFO L290 TraceCheckUtils]: 9: Hoare triple {1265#true} assume true; {1265#true} is VALID [2022-04-08 13:23:45,415 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {1265#true} {1265#true} #78#return; {1265#true} is VALID [2022-04-08 13:23:45,415 INFO L290 TraceCheckUtils]: 11: Hoare triple {1265#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {1303#(and (= main_~A~0 main_~r~0) (= main_~q~0 0))} is VALID [2022-04-08 13:23:45,416 INFO L290 TraceCheckUtils]: 12: Hoare triple {1303#(and (= main_~A~0 main_~r~0) (= main_~q~0 0))} assume !false; {1303#(and (= main_~A~0 main_~r~0) (= main_~q~0 0))} is VALID [2022-04-08 13:23:45,416 INFO L272 TraceCheckUtils]: 13: Hoare triple {1303#(and (= main_~A~0 main_~r~0) (= main_~q~0 0))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {1265#true} is VALID [2022-04-08 13:23:45,416 INFO L290 TraceCheckUtils]: 14: Hoare triple {1265#true} ~cond := #in~cond; {1265#true} is VALID [2022-04-08 13:23:45,416 INFO L290 TraceCheckUtils]: 15: Hoare triple {1265#true} assume !(0 == ~cond); {1265#true} is VALID [2022-04-08 13:23:45,416 INFO L290 TraceCheckUtils]: 16: Hoare triple {1265#true} assume true; {1265#true} is VALID [2022-04-08 13:23:45,416 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {1265#true} {1303#(and (= main_~A~0 main_~r~0) (= main_~q~0 0))} #80#return; {1303#(and (= main_~A~0 main_~r~0) (= main_~q~0 0))} is VALID [2022-04-08 13:23:45,417 INFO L272 TraceCheckUtils]: 18: Hoare triple {1303#(and (= main_~A~0 main_~r~0) (= main_~q~0 0))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {1265#true} is VALID [2022-04-08 13:23:45,417 INFO L290 TraceCheckUtils]: 19: Hoare triple {1265#true} ~cond := #in~cond; {1265#true} is VALID [2022-04-08 13:23:45,417 INFO L290 TraceCheckUtils]: 20: Hoare triple {1265#true} assume !(0 == ~cond); {1265#true} is VALID [2022-04-08 13:23:45,417 INFO L290 TraceCheckUtils]: 21: Hoare triple {1265#true} assume true; {1265#true} is VALID [2022-04-08 13:23:45,417 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {1265#true} {1303#(and (= main_~A~0 main_~r~0) (= main_~q~0 0))} #82#return; {1303#(and (= main_~A~0 main_~r~0) (= main_~q~0 0))} is VALID [2022-04-08 13:23:45,418 INFO L272 TraceCheckUtils]: 23: Hoare triple {1303#(and (= main_~A~0 main_~r~0) (= main_~q~0 0))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {1265#true} is VALID [2022-04-08 13:23:45,418 INFO L290 TraceCheckUtils]: 24: Hoare triple {1265#true} ~cond := #in~cond; {1265#true} is VALID [2022-04-08 13:23:45,418 INFO L290 TraceCheckUtils]: 25: Hoare triple {1265#true} assume !(0 == ~cond); {1265#true} is VALID [2022-04-08 13:23:45,418 INFO L290 TraceCheckUtils]: 26: Hoare triple {1265#true} assume true; {1265#true} is VALID [2022-04-08 13:23:45,418 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {1265#true} {1303#(and (= main_~A~0 main_~r~0) (= main_~q~0 0))} #84#return; {1303#(and (= main_~A~0 main_~r~0) (= main_~q~0 0))} is VALID [2022-04-08 13:23:45,419 INFO L290 TraceCheckUtils]: 28: Hoare triple {1303#(and (= main_~A~0 main_~r~0) (= main_~q~0 0))} assume !(~r~0 >= ~d~0); {1303#(and (= main_~A~0 main_~r~0) (= main_~q~0 0))} is VALID [2022-04-08 13:23:45,419 INFO L290 TraceCheckUtils]: 29: Hoare triple {1303#(and (= main_~A~0 main_~r~0) (= main_~q~0 0))} assume !false; {1303#(and (= main_~A~0 main_~r~0) (= main_~q~0 0))} is VALID [2022-04-08 13:23:45,420 INFO L272 TraceCheckUtils]: 30: Hoare triple {1303#(and (= main_~A~0 main_~r~0) (= main_~q~0 0))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {1361#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:23:45,420 INFO L290 TraceCheckUtils]: 31: Hoare triple {1361#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {1365#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:23:45,420 INFO L290 TraceCheckUtils]: 32: Hoare triple {1365#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {1266#false} is VALID [2022-04-08 13:23:45,420 INFO L290 TraceCheckUtils]: 33: Hoare triple {1266#false} assume !false; {1266#false} is VALID [2022-04-08 13:23:45,421 INFO L134 CoverageAnalysis]: Checked inductivity of 18 backedges. 6 proven. 0 refuted. 0 times theorem prover too weak. 12 trivial. 0 not checked. [2022-04-08 13:23:45,421 INFO L324 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2022-04-08 13:23:45,421 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-08 13:23:45,421 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [689739767] [2022-04-08 13:23:45,421 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-08 13:23:45,421 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [622645239] [2022-04-08 13:23:45,421 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [622645239] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:23:45,421 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:23:45,421 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [] total 5 [2022-04-08 13:23:45,421 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-08 13:23:45,421 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [270180533] [2022-04-08 13:23:45,421 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [270180533] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:23:45,421 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:23:45,422 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [] total 5 [2022-04-08 13:23:45,422 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [753065501] [2022-04-08 13:23:45,422 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-08 13:23:45,422 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 3.2) internal successors, (16), 4 states have internal predecessors, (16), 2 states have call successors, (7), 2 states have call predecessors, (7), 1 states have return successors, (5), 2 states have call predecessors, (5), 2 states have call successors, (5) Word has length 34 [2022-04-08 13:23:45,422 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-08 13:23:45,422 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 5 states, 5 states have (on average 3.2) internal successors, (16), 4 states have internal predecessors, (16), 2 states have call successors, (7), 2 states have call predecessors, (7), 1 states have return successors, (5), 2 states have call predecessors, (5), 2 states have call successors, (5) [2022-04-08 13:23:45,437 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 28 edges. 28 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:23:45,437 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 5 states [2022-04-08 13:23:45,437 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-08 13:23:45,438 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 5 interpolants. [2022-04-08 13:23:45,438 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=7, Invalid=13, Unknown=0, NotChecked=0, Total=20 [2022-04-08 13:23:45,438 INFO L87 Difference]: Start difference. First operand 52 states and 63 transitions. Second operand has 5 states, 5 states have (on average 3.2) internal successors, (16), 4 states have internal predecessors, (16), 2 states have call successors, (7), 2 states have call predecessors, (7), 1 states have return successors, (5), 2 states have call predecessors, (5), 2 states have call successors, (5) [2022-04-08 13:23:45,596 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:23:45,596 INFO L93 Difference]: Finished difference Result 65 states and 80 transitions. [2022-04-08 13:23:45,596 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 5 states. [2022-04-08 13:23:45,597 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 3.2) internal successors, (16), 4 states have internal predecessors, (16), 2 states have call successors, (7), 2 states have call predecessors, (7), 1 states have return successors, (5), 2 states have call predecessors, (5), 2 states have call successors, (5) Word has length 34 [2022-04-08 13:23:45,597 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-08 13:23:45,597 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 3.2) internal successors, (16), 4 states have internal predecessors, (16), 2 states have call successors, (7), 2 states have call predecessors, (7), 1 states have return successors, (5), 2 states have call predecessors, (5), 2 states have call successors, (5) [2022-04-08 13:23:45,598 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 55 transitions. [2022-04-08 13:23:45,598 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 3.2) internal successors, (16), 4 states have internal predecessors, (16), 2 states have call successors, (7), 2 states have call predecessors, (7), 1 states have return successors, (5), 2 states have call predecessors, (5), 2 states have call successors, (5) [2022-04-08 13:23:45,599 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 55 transitions. [2022-04-08 13:23:45,599 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 5 states and 55 transitions. [2022-04-08 13:23:45,636 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 55 edges. 55 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:23:45,637 INFO L225 Difference]: With dead ends: 65 [2022-04-08 13:23:45,637 INFO L226 Difference]: Without dead ends: 58 [2022-04-08 13:23:45,637 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 34 GetRequests, 30 SyntacticMatches, 0 SemanticMatches, 4 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=11, Invalid=19, Unknown=0, NotChecked=0, Total=30 [2022-04-08 13:23:45,638 INFO L913 BasicCegarLoop]: 31 mSDtfsCounter, 9 mSDsluCounter, 72 mSDsCounter, 0 mSdLazyCounter, 49 mSolverCounterSat, 3 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.0s Time, 0 mProtectedPredicate, 0 mProtectedAction, 12 SdHoareTripleChecker+Valid, 103 SdHoareTripleChecker+Invalid, 52 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 3 IncrementalHoareTripleChecker+Valid, 49 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.0s IncrementalHoareTripleChecker+Time [2022-04-08 13:23:45,638 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [12 Valid, 103 Invalid, 52 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [3 Valid, 49 Invalid, 0 Unknown, 0 Unchecked, 0.0s Time] [2022-04-08 13:23:45,639 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 58 states. [2022-04-08 13:23:45,658 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 58 to 57. [2022-04-08 13:23:45,658 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-08 13:23:45,659 INFO L82 GeneralOperation]: Start isEquivalent. First operand 58 states. Second operand has 57 states, 33 states have (on average 1.1818181818181819) internal successors, (39), 35 states have internal predecessors, (39), 16 states have call successors, (16), 8 states have call predecessors, (16), 7 states have return successors, (14), 13 states have call predecessors, (14), 14 states have call successors, (14) [2022-04-08 13:23:45,659 INFO L74 IsIncluded]: Start isIncluded. First operand 58 states. Second operand has 57 states, 33 states have (on average 1.1818181818181819) internal successors, (39), 35 states have internal predecessors, (39), 16 states have call successors, (16), 8 states have call predecessors, (16), 7 states have return successors, (14), 13 states have call predecessors, (14), 14 states have call successors, (14) [2022-04-08 13:23:45,659 INFO L87 Difference]: Start difference. First operand 58 states. Second operand has 57 states, 33 states have (on average 1.1818181818181819) internal successors, (39), 35 states have internal predecessors, (39), 16 states have call successors, (16), 8 states have call predecessors, (16), 7 states have return successors, (14), 13 states have call predecessors, (14), 14 states have call successors, (14) [2022-04-08 13:23:45,661 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:23:45,661 INFO L93 Difference]: Finished difference Result 58 states and 70 transitions. [2022-04-08 13:23:45,661 INFO L276 IsEmpty]: Start isEmpty. Operand 58 states and 70 transitions. [2022-04-08 13:23:45,661 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:23:45,661 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:23:45,662 INFO L74 IsIncluded]: Start isIncluded. First operand has 57 states, 33 states have (on average 1.1818181818181819) internal successors, (39), 35 states have internal predecessors, (39), 16 states have call successors, (16), 8 states have call predecessors, (16), 7 states have return successors, (14), 13 states have call predecessors, (14), 14 states have call successors, (14) Second operand 58 states. [2022-04-08 13:23:45,662 INFO L87 Difference]: Start difference. First operand has 57 states, 33 states have (on average 1.1818181818181819) internal successors, (39), 35 states have internal predecessors, (39), 16 states have call successors, (16), 8 states have call predecessors, (16), 7 states have return successors, (14), 13 states have call predecessors, (14), 14 states have call successors, (14) Second operand 58 states. [2022-04-08 13:23:45,663 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:23:45,663 INFO L93 Difference]: Finished difference Result 58 states and 70 transitions. [2022-04-08 13:23:45,664 INFO L276 IsEmpty]: Start isEmpty. Operand 58 states and 70 transitions. [2022-04-08 13:23:45,664 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:23:45,664 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:23:45,664 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-08 13:23:45,664 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-08 13:23:45,664 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 57 states, 33 states have (on average 1.1818181818181819) internal successors, (39), 35 states have internal predecessors, (39), 16 states have call successors, (16), 8 states have call predecessors, (16), 7 states have return successors, (14), 13 states have call predecessors, (14), 14 states have call successors, (14) [2022-04-08 13:23:45,666 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 57 states to 57 states and 69 transitions. [2022-04-08 13:23:45,666 INFO L78 Accepts]: Start accepts. Automaton has 57 states and 69 transitions. Word has length 34 [2022-04-08 13:23:45,666 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-08 13:23:45,666 INFO L478 AbstractCegarLoop]: Abstraction has 57 states and 69 transitions. [2022-04-08 13:23:45,666 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 5 states, 5 states have (on average 3.2) internal successors, (16), 4 states have internal predecessors, (16), 2 states have call successors, (7), 2 states have call predecessors, (7), 1 states have return successors, (5), 2 states have call predecessors, (5), 2 states have call successors, (5) [2022-04-08 13:23:45,666 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 57 states and 69 transitions. [2022-04-08 13:23:45,720 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 69 edges. 69 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:23:45,720 INFO L276 IsEmpty]: Start isEmpty. Operand 57 states and 69 transitions. [2022-04-08 13:23:45,721 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 45 [2022-04-08 13:23:45,721 INFO L491 BasicCegarLoop]: Found error trace [2022-04-08 13:23:45,721 INFO L499 BasicCegarLoop]: trace histogram [6, 5, 5, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-08 13:23:45,740 INFO L552 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (3)] Ended with exit code 0 [2022-04-08 13:23:45,935 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable4,3 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:23:45,935 INFO L403 AbstractCegarLoop]: === Iteration 6 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-08 13:23:45,936 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-08 13:23:45,936 INFO L85 PathProgramCache]: Analyzing trace with hash -1576096488, now seen corresponding path program 1 times [2022-04-08 13:23:45,936 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-08 13:23:45,936 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [299872175] [2022-04-08 13:23:49,854 INFO L97 AcceleratorQvasr]: Qvasr could not accelerate loop because java.lang.UnsupportedOperationException: Cannot deal with arrays. [2022-04-08 13:23:49,854 INFO L274 tedInterpolationCore]: Could not compute an accelerate. [2022-04-08 13:23:49,854 INFO L85 PathProgramCache]: Analyzing trace with hash -1576096488, now seen corresponding path program 2 times [2022-04-08 13:23:49,854 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-08 13:23:49,854 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [448792251] [2022-04-08 13:23:49,854 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-08 13:23:49,855 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-08 13:23:49,865 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-08 13:23:49,865 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [102568448] [2022-04-08 13:23:49,865 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-08 13:23:49,865 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:23:49,865 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-08 13:23:49,866 INFO L229 MonitoredProcess]: Starting monitored process 4 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-08 13:23:49,867 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (4)] Waiting until timeout for monitored process [2022-04-08 13:23:49,899 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-08 13:23:49,899 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-08 13:23:49,900 INFO L263 TraceCheckSpWp]: Trace formula consists of 123 conjuncts, 13 conjunts are in the unsatisfiable core [2022-04-08 13:23:49,908 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:23:49,909 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-08 13:23:50,084 INFO L272 TraceCheckUtils]: 0: Hoare triple {1733#true} call ULTIMATE.init(); {1733#true} is VALID [2022-04-08 13:23:50,085 INFO L290 TraceCheckUtils]: 1: Hoare triple {1733#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {1733#true} is VALID [2022-04-08 13:23:50,085 INFO L290 TraceCheckUtils]: 2: Hoare triple {1733#true} assume true; {1733#true} is VALID [2022-04-08 13:23:50,085 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {1733#true} {1733#true} #94#return; {1733#true} is VALID [2022-04-08 13:23:50,085 INFO L272 TraceCheckUtils]: 4: Hoare triple {1733#true} call #t~ret5 := main(); {1733#true} is VALID [2022-04-08 13:23:50,085 INFO L290 TraceCheckUtils]: 5: Hoare triple {1733#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {1733#true} is VALID [2022-04-08 13:23:50,085 INFO L272 TraceCheckUtils]: 6: Hoare triple {1733#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {1733#true} is VALID [2022-04-08 13:23:50,085 INFO L290 TraceCheckUtils]: 7: Hoare triple {1733#true} ~cond := #in~cond; {1733#true} is VALID [2022-04-08 13:23:50,085 INFO L290 TraceCheckUtils]: 8: Hoare triple {1733#true} assume !(0 == ~cond); {1733#true} is VALID [2022-04-08 13:23:50,085 INFO L290 TraceCheckUtils]: 9: Hoare triple {1733#true} assume true; {1733#true} is VALID [2022-04-08 13:23:50,086 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {1733#true} {1733#true} #78#return; {1733#true} is VALID [2022-04-08 13:23:50,086 INFO L290 TraceCheckUtils]: 11: Hoare triple {1733#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {1771#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:23:50,086 INFO L290 TraceCheckUtils]: 12: Hoare triple {1771#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !false; {1771#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:23:50,086 INFO L272 TraceCheckUtils]: 13: Hoare triple {1771#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {1733#true} is VALID [2022-04-08 13:23:50,087 INFO L290 TraceCheckUtils]: 14: Hoare triple {1733#true} ~cond := #in~cond; {1733#true} is VALID [2022-04-08 13:23:50,087 INFO L290 TraceCheckUtils]: 15: Hoare triple {1733#true} assume !(0 == ~cond); {1733#true} is VALID [2022-04-08 13:23:50,087 INFO L290 TraceCheckUtils]: 16: Hoare triple {1733#true} assume true; {1733#true} is VALID [2022-04-08 13:23:50,087 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {1733#true} {1771#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #80#return; {1771#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:23:50,088 INFO L272 TraceCheckUtils]: 18: Hoare triple {1771#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {1733#true} is VALID [2022-04-08 13:23:50,088 INFO L290 TraceCheckUtils]: 19: Hoare triple {1733#true} ~cond := #in~cond; {1733#true} is VALID [2022-04-08 13:23:50,090 INFO L290 TraceCheckUtils]: 20: Hoare triple {1733#true} assume !(0 == ~cond); {1733#true} is VALID [2022-04-08 13:23:50,090 INFO L290 TraceCheckUtils]: 21: Hoare triple {1733#true} assume true; {1733#true} is VALID [2022-04-08 13:23:50,092 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {1733#true} {1771#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #82#return; {1771#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:23:50,092 INFO L272 TraceCheckUtils]: 23: Hoare triple {1771#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {1733#true} is VALID [2022-04-08 13:23:50,092 INFO L290 TraceCheckUtils]: 24: Hoare triple {1733#true} ~cond := #in~cond; {1733#true} is VALID [2022-04-08 13:23:50,092 INFO L290 TraceCheckUtils]: 25: Hoare triple {1733#true} assume !(0 == ~cond); {1733#true} is VALID [2022-04-08 13:23:50,092 INFO L290 TraceCheckUtils]: 26: Hoare triple {1733#true} assume true; {1733#true} is VALID [2022-04-08 13:23:50,093 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {1733#true} {1771#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #84#return; {1771#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:23:50,093 INFO L290 TraceCheckUtils]: 28: Hoare triple {1771#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {1823#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:23:50,093 INFO L290 TraceCheckUtils]: 29: Hoare triple {1823#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} assume !false; {1823#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:23:50,094 INFO L272 TraceCheckUtils]: 30: Hoare triple {1823#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {1733#true} is VALID [2022-04-08 13:23:50,094 INFO L290 TraceCheckUtils]: 31: Hoare triple {1733#true} ~cond := #in~cond; {1733#true} is VALID [2022-04-08 13:23:50,094 INFO L290 TraceCheckUtils]: 32: Hoare triple {1733#true} assume !(0 == ~cond); {1733#true} is VALID [2022-04-08 13:23:50,094 INFO L290 TraceCheckUtils]: 33: Hoare triple {1733#true} assume true; {1733#true} is VALID [2022-04-08 13:23:50,095 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {1733#true} {1823#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} #80#return; {1823#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:23:50,095 INFO L272 TraceCheckUtils]: 35: Hoare triple {1823#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {1733#true} is VALID [2022-04-08 13:23:50,096 INFO L290 TraceCheckUtils]: 36: Hoare triple {1733#true} ~cond := #in~cond; {1733#true} is VALID [2022-04-08 13:23:50,096 INFO L290 TraceCheckUtils]: 37: Hoare triple {1733#true} assume !(0 == ~cond); {1733#true} is VALID [2022-04-08 13:23:50,096 INFO L290 TraceCheckUtils]: 38: Hoare triple {1733#true} assume true; {1733#true} is VALID [2022-04-08 13:23:50,098 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {1733#true} {1823#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} #82#return; {1823#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:23:50,101 INFO L272 TraceCheckUtils]: 40: Hoare triple {1823#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {1860#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:23:50,101 INFO L290 TraceCheckUtils]: 41: Hoare triple {1860#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {1864#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:23:50,102 INFO L290 TraceCheckUtils]: 42: Hoare triple {1864#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {1734#false} is VALID [2022-04-08 13:23:50,102 INFO L290 TraceCheckUtils]: 43: Hoare triple {1734#false} assume !false; {1734#false} is VALID [2022-04-08 13:23:50,102 INFO L134 CoverageAnalysis]: Checked inductivity of 54 backedges. 10 proven. 4 refuted. 0 times theorem prover too weak. 40 trivial. 0 not checked. [2022-04-08 13:23:50,102 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-08 13:23:50,261 INFO L290 TraceCheckUtils]: 43: Hoare triple {1734#false} assume !false; {1734#false} is VALID [2022-04-08 13:23:50,262 INFO L290 TraceCheckUtils]: 42: Hoare triple {1864#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {1734#false} is VALID [2022-04-08 13:23:50,262 INFO L290 TraceCheckUtils]: 41: Hoare triple {1860#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {1864#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:23:50,263 INFO L272 TraceCheckUtils]: 40: Hoare triple {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {1860#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:23:50,263 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {1733#true} {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} #82#return; {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:23:50,263 INFO L290 TraceCheckUtils]: 38: Hoare triple {1733#true} assume true; {1733#true} is VALID [2022-04-08 13:23:50,263 INFO L290 TraceCheckUtils]: 37: Hoare triple {1733#true} assume !(0 == ~cond); {1733#true} is VALID [2022-04-08 13:23:50,263 INFO L290 TraceCheckUtils]: 36: Hoare triple {1733#true} ~cond := #in~cond; {1733#true} is VALID [2022-04-08 13:23:50,264 INFO L272 TraceCheckUtils]: 35: Hoare triple {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {1733#true} is VALID [2022-04-08 13:23:50,266 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {1733#true} {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} #80#return; {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:23:50,266 INFO L290 TraceCheckUtils]: 33: Hoare triple {1733#true} assume true; {1733#true} is VALID [2022-04-08 13:23:50,266 INFO L290 TraceCheckUtils]: 32: Hoare triple {1733#true} assume !(0 == ~cond); {1733#true} is VALID [2022-04-08 13:23:50,266 INFO L290 TraceCheckUtils]: 31: Hoare triple {1733#true} ~cond := #in~cond; {1733#true} is VALID [2022-04-08 13:23:50,266 INFO L272 TraceCheckUtils]: 30: Hoare triple {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {1733#true} is VALID [2022-04-08 13:23:50,269 INFO L290 TraceCheckUtils]: 29: Hoare triple {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} assume !false; {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:23:50,272 INFO L290 TraceCheckUtils]: 28: Hoare triple {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:23:50,273 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {1733#true} {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} #84#return; {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:23:50,273 INFO L290 TraceCheckUtils]: 26: Hoare triple {1733#true} assume true; {1733#true} is VALID [2022-04-08 13:23:50,273 INFO L290 TraceCheckUtils]: 25: Hoare triple {1733#true} assume !(0 == ~cond); {1733#true} is VALID [2022-04-08 13:23:50,273 INFO L290 TraceCheckUtils]: 24: Hoare triple {1733#true} ~cond := #in~cond; {1733#true} is VALID [2022-04-08 13:23:50,273 INFO L272 TraceCheckUtils]: 23: Hoare triple {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {1733#true} is VALID [2022-04-08 13:23:50,274 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {1733#true} {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} #82#return; {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:23:50,274 INFO L290 TraceCheckUtils]: 21: Hoare triple {1733#true} assume true; {1733#true} is VALID [2022-04-08 13:23:50,274 INFO L290 TraceCheckUtils]: 20: Hoare triple {1733#true} assume !(0 == ~cond); {1733#true} is VALID [2022-04-08 13:23:50,275 INFO L290 TraceCheckUtils]: 19: Hoare triple {1733#true} ~cond := #in~cond; {1733#true} is VALID [2022-04-08 13:23:50,275 INFO L272 TraceCheckUtils]: 18: Hoare triple {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {1733#true} is VALID [2022-04-08 13:23:50,275 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {1733#true} {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} #80#return; {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:23:50,275 INFO L290 TraceCheckUtils]: 16: Hoare triple {1733#true} assume true; {1733#true} is VALID [2022-04-08 13:23:50,275 INFO L290 TraceCheckUtils]: 15: Hoare triple {1733#true} assume !(0 == ~cond); {1733#true} is VALID [2022-04-08 13:23:50,276 INFO L290 TraceCheckUtils]: 14: Hoare triple {1733#true} ~cond := #in~cond; {1733#true} is VALID [2022-04-08 13:23:50,276 INFO L272 TraceCheckUtils]: 13: Hoare triple {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {1733#true} is VALID [2022-04-08 13:23:50,276 INFO L290 TraceCheckUtils]: 12: Hoare triple {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} assume !false; {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:23:50,276 INFO L290 TraceCheckUtils]: 11: Hoare triple {1733#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {1880#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:23:50,276 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {1733#true} {1733#true} #78#return; {1733#true} is VALID [2022-04-08 13:23:50,276 INFO L290 TraceCheckUtils]: 9: Hoare triple {1733#true} assume true; {1733#true} is VALID [2022-04-08 13:23:50,277 INFO L290 TraceCheckUtils]: 8: Hoare triple {1733#true} assume !(0 == ~cond); {1733#true} is VALID [2022-04-08 13:23:50,277 INFO L290 TraceCheckUtils]: 7: Hoare triple {1733#true} ~cond := #in~cond; {1733#true} is VALID [2022-04-08 13:23:50,277 INFO L272 TraceCheckUtils]: 6: Hoare triple {1733#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {1733#true} is VALID [2022-04-08 13:23:50,277 INFO L290 TraceCheckUtils]: 5: Hoare triple {1733#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {1733#true} is VALID [2022-04-08 13:23:50,277 INFO L272 TraceCheckUtils]: 4: Hoare triple {1733#true} call #t~ret5 := main(); {1733#true} is VALID [2022-04-08 13:23:50,277 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {1733#true} {1733#true} #94#return; {1733#true} is VALID [2022-04-08 13:23:50,277 INFO L290 TraceCheckUtils]: 2: Hoare triple {1733#true} assume true; {1733#true} is VALID [2022-04-08 13:23:50,277 INFO L290 TraceCheckUtils]: 1: Hoare triple {1733#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {1733#true} is VALID [2022-04-08 13:23:50,277 INFO L272 TraceCheckUtils]: 0: Hoare triple {1733#true} call ULTIMATE.init(); {1733#true} is VALID [2022-04-08 13:23:50,277 INFO L134 CoverageAnalysis]: Checked inductivity of 54 backedges. 10 proven. 0 refuted. 0 times theorem prover too weak. 44 trivial. 0 not checked. [2022-04-08 13:23:50,278 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-08 13:23:50,278 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [448792251] [2022-04-08 13:23:50,278 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-08 13:23:50,278 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [102568448] [2022-04-08 13:23:50,278 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [102568448] provided 1 perfect and 1 imperfect interpolant sequences [2022-04-08 13:23:50,278 INFO L184 FreeRefinementEngine]: Found 1 perfect and 1 imperfect interpolant sequences. [2022-04-08 13:23:50,278 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [6] total 7 [2022-04-08 13:23:50,278 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-08 13:23:50,278 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [299872175] [2022-04-08 13:23:50,278 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [299872175] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:23:50,278 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:23:50,278 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [] total 5 [2022-04-08 13:23:50,278 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [292055601] [2022-04-08 13:23:50,278 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-08 13:23:50,279 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 3.0) internal successors, (15), 4 states have internal predecessors, (15), 2 states have call successors, (7), 2 states have call predecessors, (7), 1 states have return successors, (5), 2 states have call predecessors, (5), 2 states have call successors, (5) Word has length 44 [2022-04-08 13:23:50,279 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-08 13:23:50,279 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 5 states, 5 states have (on average 3.0) internal successors, (15), 4 states have internal predecessors, (15), 2 states have call successors, (7), 2 states have call predecessors, (7), 1 states have return successors, (5), 2 states have call predecessors, (5), 2 states have call successors, (5) [2022-04-08 13:23:50,297 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 27 edges. 27 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:23:50,298 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 5 states [2022-04-08 13:23:50,298 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-08 13:23:50,298 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 5 interpolants. [2022-04-08 13:23:50,298 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=13, Invalid=29, Unknown=0, NotChecked=0, Total=42 [2022-04-08 13:23:50,298 INFO L87 Difference]: Start difference. First operand 57 states and 69 transitions. Second operand has 5 states, 5 states have (on average 3.0) internal successors, (15), 4 states have internal predecessors, (15), 2 states have call successors, (7), 2 states have call predecessors, (7), 1 states have return successors, (5), 2 states have call predecessors, (5), 2 states have call successors, (5) [2022-04-08 13:23:52,550 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:23:52,550 INFO L93 Difference]: Finished difference Result 69 states and 84 transitions. [2022-04-08 13:23:52,550 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 5 states. [2022-04-08 13:23:52,550 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 3.0) internal successors, (15), 4 states have internal predecessors, (15), 2 states have call successors, (7), 2 states have call predecessors, (7), 1 states have return successors, (5), 2 states have call predecessors, (5), 2 states have call successors, (5) Word has length 44 [2022-04-08 13:23:52,550 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-08 13:23:52,551 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 3.0) internal successors, (15), 4 states have internal predecessors, (15), 2 states have call successors, (7), 2 states have call predecessors, (7), 1 states have return successors, (5), 2 states have call predecessors, (5), 2 states have call successors, (5) [2022-04-08 13:23:52,551 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 53 transitions. [2022-04-08 13:23:52,552 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 3.0) internal successors, (15), 4 states have internal predecessors, (15), 2 states have call successors, (7), 2 states have call predecessors, (7), 1 states have return successors, (5), 2 states have call predecessors, (5), 2 states have call successors, (5) [2022-04-08 13:23:52,552 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 53 transitions. [2022-04-08 13:23:52,552 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 5 states and 53 transitions. [2022-04-08 13:23:52,604 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 53 edges. 53 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:23:52,605 INFO L225 Difference]: With dead ends: 69 [2022-04-08 13:23:52,606 INFO L226 Difference]: Without dead ends: 67 [2022-04-08 13:23:52,606 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 88 GetRequests, 80 SyntacticMatches, 2 SemanticMatches, 6 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=17, Invalid=39, Unknown=0, NotChecked=0, Total=56 [2022-04-08 13:23:52,606 INFO L913 BasicCegarLoop]: 36 mSDtfsCounter, 8 mSDsluCounter, 76 mSDsCounter, 0 mSdLazyCounter, 47 mSolverCounterSat, 1 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.1s Time, 0 mProtectedPredicate, 0 mProtectedAction, 11 SdHoareTripleChecker+Valid, 112 SdHoareTripleChecker+Invalid, 48 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 1 IncrementalHoareTripleChecker+Valid, 47 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.1s IncrementalHoareTripleChecker+Time [2022-04-08 13:23:52,607 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [11 Valid, 112 Invalid, 48 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [1 Valid, 47 Invalid, 0 Unknown, 0 Unchecked, 0.1s Time] [2022-04-08 13:23:52,607 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 67 states. [2022-04-08 13:23:52,635 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 67 to 64. [2022-04-08 13:23:52,636 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-08 13:23:52,636 INFO L82 GeneralOperation]: Start isEquivalent. First operand 67 states. Second operand has 64 states, 37 states have (on average 1.162162162162162) internal successors, (43), 40 states have internal predecessors, (43), 18 states have call successors, (18), 9 states have call predecessors, (18), 8 states have return successors, (16), 14 states have call predecessors, (16), 16 states have call successors, (16) [2022-04-08 13:23:52,636 INFO L74 IsIncluded]: Start isIncluded. First operand 67 states. Second operand has 64 states, 37 states have (on average 1.162162162162162) internal successors, (43), 40 states have internal predecessors, (43), 18 states have call successors, (18), 9 states have call predecessors, (18), 8 states have return successors, (16), 14 states have call predecessors, (16), 16 states have call successors, (16) [2022-04-08 13:23:52,636 INFO L87 Difference]: Start difference. First operand 67 states. Second operand has 64 states, 37 states have (on average 1.162162162162162) internal successors, (43), 40 states have internal predecessors, (43), 18 states have call successors, (18), 9 states have call predecessors, (18), 8 states have return successors, (16), 14 states have call predecessors, (16), 16 states have call successors, (16) [2022-04-08 13:23:52,641 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:23:52,641 INFO L93 Difference]: Finished difference Result 67 states and 82 transitions. [2022-04-08 13:23:52,641 INFO L276 IsEmpty]: Start isEmpty. Operand 67 states and 82 transitions. [2022-04-08 13:23:52,642 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:23:52,642 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:23:52,643 INFO L74 IsIncluded]: Start isIncluded. First operand has 64 states, 37 states have (on average 1.162162162162162) internal successors, (43), 40 states have internal predecessors, (43), 18 states have call successors, (18), 9 states have call predecessors, (18), 8 states have return successors, (16), 14 states have call predecessors, (16), 16 states have call successors, (16) Second operand 67 states. [2022-04-08 13:23:52,643 INFO L87 Difference]: Start difference. First operand has 64 states, 37 states have (on average 1.162162162162162) internal successors, (43), 40 states have internal predecessors, (43), 18 states have call successors, (18), 9 states have call predecessors, (18), 8 states have return successors, (16), 14 states have call predecessors, (16), 16 states have call successors, (16) Second operand 67 states. [2022-04-08 13:23:52,646 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:23:52,646 INFO L93 Difference]: Finished difference Result 67 states and 82 transitions. [2022-04-08 13:23:52,646 INFO L276 IsEmpty]: Start isEmpty. Operand 67 states and 82 transitions. [2022-04-08 13:23:52,646 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:23:52,646 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:23:52,646 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-08 13:23:52,646 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-08 13:23:52,647 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 64 states, 37 states have (on average 1.162162162162162) internal successors, (43), 40 states have internal predecessors, (43), 18 states have call successors, (18), 9 states have call predecessors, (18), 8 states have return successors, (16), 14 states have call predecessors, (16), 16 states have call successors, (16) [2022-04-08 13:23:52,649 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 64 states to 64 states and 77 transitions. [2022-04-08 13:23:52,649 INFO L78 Accepts]: Start accepts. Automaton has 64 states and 77 transitions. Word has length 44 [2022-04-08 13:23:52,649 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-08 13:23:52,649 INFO L478 AbstractCegarLoop]: Abstraction has 64 states and 77 transitions. [2022-04-08 13:23:52,649 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 5 states, 5 states have (on average 3.0) internal successors, (15), 4 states have internal predecessors, (15), 2 states have call successors, (7), 2 states have call predecessors, (7), 1 states have return successors, (5), 2 states have call predecessors, (5), 2 states have call successors, (5) [2022-04-08 13:23:52,649 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 64 states and 77 transitions. [2022-04-08 13:23:52,725 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 77 edges. 77 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:23:52,725 INFO L276 IsEmpty]: Start isEmpty. Operand 64 states and 77 transitions. [2022-04-08 13:23:52,726 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 65 [2022-04-08 13:23:52,726 INFO L491 BasicCegarLoop]: Found error trace [2022-04-08 13:23:52,726 INFO L499 BasicCegarLoop]: trace histogram [9, 8, 8, 2, 2, 2, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-08 13:23:52,745 INFO L552 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (4)] Ended with exit code 0 [2022-04-08 13:23:52,926 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable5,4 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:23:52,927 INFO L403 AbstractCegarLoop]: === Iteration 7 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-08 13:23:52,927 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-08 13:23:52,927 INFO L85 PathProgramCache]: Analyzing trace with hash 1615471943, now seen corresponding path program 1 times [2022-04-08 13:23:52,927 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-08 13:23:52,927 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [703335374] [2022-04-08 13:23:59,082 INFO L97 AcceleratorQvasr]: Qvasr could not accelerate loop because java.lang.UnsupportedOperationException: Cannot deal with arrays. [2022-04-08 13:23:59,082 INFO L274 tedInterpolationCore]: Could not compute an accelerate. [2022-04-08 13:23:59,082 INFO L85 PathProgramCache]: Analyzing trace with hash 1615471943, now seen corresponding path program 2 times [2022-04-08 13:23:59,082 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-08 13:23:59,082 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [119658855] [2022-04-08 13:23:59,082 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-08 13:23:59,082 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-08 13:23:59,097 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-08 13:23:59,097 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1876775598] [2022-04-08 13:23:59,097 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-08 13:23:59,097 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:23:59,097 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-08 13:23:59,108 INFO L229 MonitoredProcess]: Starting monitored process 5 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-08 13:23:59,110 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (5)] Waiting until timeout for monitored process [2022-04-08 13:23:59,150 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-08 13:23:59,150 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-08 13:23:59,151 INFO L263 TraceCheckSpWp]: Trace formula consists of 163 conjuncts, 25 conjunts are in the unsatisfiable core [2022-04-08 13:23:59,165 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:23:59,167 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-08 13:23:59,544 INFO L272 TraceCheckUtils]: 0: Hoare triple {2405#true} call ULTIMATE.init(); {2405#true} is VALID [2022-04-08 13:23:59,544 INFO L290 TraceCheckUtils]: 1: Hoare triple {2405#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {2405#true} is VALID [2022-04-08 13:23:59,544 INFO L290 TraceCheckUtils]: 2: Hoare triple {2405#true} assume true; {2405#true} is VALID [2022-04-08 13:23:59,544 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {2405#true} {2405#true} #94#return; {2405#true} is VALID [2022-04-08 13:23:59,544 INFO L272 TraceCheckUtils]: 4: Hoare triple {2405#true} call #t~ret5 := main(); {2405#true} is VALID [2022-04-08 13:23:59,545 INFO L290 TraceCheckUtils]: 5: Hoare triple {2405#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {2405#true} is VALID [2022-04-08 13:23:59,545 INFO L272 TraceCheckUtils]: 6: Hoare triple {2405#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {2405#true} is VALID [2022-04-08 13:23:59,545 INFO L290 TraceCheckUtils]: 7: Hoare triple {2405#true} ~cond := #in~cond; {2405#true} is VALID [2022-04-08 13:23:59,545 INFO L290 TraceCheckUtils]: 8: Hoare triple {2405#true} assume !(0 == ~cond); {2405#true} is VALID [2022-04-08 13:23:59,549 INFO L290 TraceCheckUtils]: 9: Hoare triple {2405#true} assume true; {2405#true} is VALID [2022-04-08 13:23:59,550 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {2405#true} {2405#true} #78#return; {2405#true} is VALID [2022-04-08 13:23:59,551 INFO L290 TraceCheckUtils]: 11: Hoare triple {2405#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {2443#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:23:59,552 INFO L290 TraceCheckUtils]: 12: Hoare triple {2443#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !false; {2443#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:23:59,554 INFO L272 TraceCheckUtils]: 13: Hoare triple {2443#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {2405#true} is VALID [2022-04-08 13:23:59,555 INFO L290 TraceCheckUtils]: 14: Hoare triple {2405#true} ~cond := #in~cond; {2405#true} is VALID [2022-04-08 13:23:59,556 INFO L290 TraceCheckUtils]: 15: Hoare triple {2405#true} assume !(0 == ~cond); {2405#true} is VALID [2022-04-08 13:23:59,556 INFO L290 TraceCheckUtils]: 16: Hoare triple {2405#true} assume true; {2405#true} is VALID [2022-04-08 13:23:59,556 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {2405#true} {2443#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #80#return; {2443#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:23:59,557 INFO L272 TraceCheckUtils]: 18: Hoare triple {2443#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {2405#true} is VALID [2022-04-08 13:23:59,558 INFO L290 TraceCheckUtils]: 19: Hoare triple {2405#true} ~cond := #in~cond; {2405#true} is VALID [2022-04-08 13:23:59,558 INFO L290 TraceCheckUtils]: 20: Hoare triple {2405#true} assume !(0 == ~cond); {2405#true} is VALID [2022-04-08 13:23:59,558 INFO L290 TraceCheckUtils]: 21: Hoare triple {2405#true} assume true; {2405#true} is VALID [2022-04-08 13:23:59,560 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {2405#true} {2443#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #82#return; {2443#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:23:59,560 INFO L272 TraceCheckUtils]: 23: Hoare triple {2443#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {2405#true} is VALID [2022-04-08 13:23:59,561 INFO L290 TraceCheckUtils]: 24: Hoare triple {2405#true} ~cond := #in~cond; {2405#true} is VALID [2022-04-08 13:23:59,563 INFO L290 TraceCheckUtils]: 25: Hoare triple {2405#true} assume !(0 == ~cond); {2405#true} is VALID [2022-04-08 13:23:59,563 INFO L290 TraceCheckUtils]: 26: Hoare triple {2405#true} assume true; {2405#true} is VALID [2022-04-08 13:23:59,564 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {2405#true} {2443#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #84#return; {2443#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:23:59,564 INFO L290 TraceCheckUtils]: 28: Hoare triple {2443#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:23:59,565 INFO L290 TraceCheckUtils]: 29: Hoare triple {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} assume !false; {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:23:59,565 INFO L272 TraceCheckUtils]: 30: Hoare triple {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {2405#true} is VALID [2022-04-08 13:23:59,565 INFO L290 TraceCheckUtils]: 31: Hoare triple {2405#true} ~cond := #in~cond; {2405#true} is VALID [2022-04-08 13:23:59,565 INFO L290 TraceCheckUtils]: 32: Hoare triple {2405#true} assume !(0 == ~cond); {2405#true} is VALID [2022-04-08 13:23:59,565 INFO L290 TraceCheckUtils]: 33: Hoare triple {2405#true} assume true; {2405#true} is VALID [2022-04-08 13:23:59,565 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {2405#true} {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #80#return; {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:23:59,565 INFO L272 TraceCheckUtils]: 35: Hoare triple {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {2405#true} is VALID [2022-04-08 13:23:59,566 INFO L290 TraceCheckUtils]: 36: Hoare triple {2405#true} ~cond := #in~cond; {2405#true} is VALID [2022-04-08 13:23:59,566 INFO L290 TraceCheckUtils]: 37: Hoare triple {2405#true} assume !(0 == ~cond); {2405#true} is VALID [2022-04-08 13:23:59,566 INFO L290 TraceCheckUtils]: 38: Hoare triple {2405#true} assume true; {2405#true} is VALID [2022-04-08 13:23:59,566 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {2405#true} {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #82#return; {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:23:59,566 INFO L272 TraceCheckUtils]: 40: Hoare triple {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {2405#true} is VALID [2022-04-08 13:23:59,566 INFO L290 TraceCheckUtils]: 41: Hoare triple {2405#true} ~cond := #in~cond; {2405#true} is VALID [2022-04-08 13:23:59,566 INFO L290 TraceCheckUtils]: 42: Hoare triple {2405#true} assume !(0 == ~cond); {2405#true} is VALID [2022-04-08 13:23:59,566 INFO L290 TraceCheckUtils]: 43: Hoare triple {2405#true} assume true; {2405#true} is VALID [2022-04-08 13:23:59,567 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {2405#true} {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #84#return; {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:23:59,567 INFO L290 TraceCheckUtils]: 45: Hoare triple {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} assume !(~r~0 >= ~d~0); {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:23:59,568 INFO L290 TraceCheckUtils]: 46: Hoare triple {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} assume !false; {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:23:59,568 INFO L272 TraceCheckUtils]: 47: Hoare triple {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {2405#true} is VALID [2022-04-08 13:23:59,568 INFO L290 TraceCheckUtils]: 48: Hoare triple {2405#true} ~cond := #in~cond; {2405#true} is VALID [2022-04-08 13:23:59,568 INFO L290 TraceCheckUtils]: 49: Hoare triple {2405#true} assume !(0 == ~cond); {2405#true} is VALID [2022-04-08 13:23:59,568 INFO L290 TraceCheckUtils]: 50: Hoare triple {2405#true} assume true; {2405#true} is VALID [2022-04-08 13:23:59,568 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {2405#true} {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #86#return; {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:23:59,569 INFO L272 TraceCheckUtils]: 52: Hoare triple {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {2405#true} is VALID [2022-04-08 13:23:59,569 INFO L290 TraceCheckUtils]: 53: Hoare triple {2405#true} ~cond := #in~cond; {2405#true} is VALID [2022-04-08 13:23:59,569 INFO L290 TraceCheckUtils]: 54: Hoare triple {2405#true} assume !(0 == ~cond); {2405#true} is VALID [2022-04-08 13:23:59,569 INFO L290 TraceCheckUtils]: 55: Hoare triple {2405#true} assume true; {2405#true} is VALID [2022-04-08 13:23:59,569 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {2405#true} {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #88#return; {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:23:59,570 INFO L290 TraceCheckUtils]: 57: Hoare triple {2495#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {2443#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:23:59,570 INFO L290 TraceCheckUtils]: 58: Hoare triple {2443#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {2586#(and (= (+ main_~A~0 (* (- 1) main_~r~0)) main_~B~0) (= main_~B~0 1) (= main_~q~0 1))} is VALID [2022-04-08 13:23:59,571 INFO L290 TraceCheckUtils]: 59: Hoare triple {2586#(and (= (+ main_~A~0 (* (- 1) main_~r~0)) main_~B~0) (= main_~B~0 1) (= main_~q~0 1))} assume !false; {2586#(and (= (+ main_~A~0 (* (- 1) main_~r~0)) main_~B~0) (= main_~B~0 1) (= main_~q~0 1))} is VALID [2022-04-08 13:23:59,571 INFO L272 TraceCheckUtils]: 60: Hoare triple {2586#(and (= (+ main_~A~0 (* (- 1) main_~r~0)) main_~B~0) (= main_~B~0 1) (= main_~q~0 1))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {2593#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:23:59,572 INFO L290 TraceCheckUtils]: 61: Hoare triple {2593#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {2597#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:23:59,572 INFO L290 TraceCheckUtils]: 62: Hoare triple {2597#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {2406#false} is VALID [2022-04-08 13:23:59,572 INFO L290 TraceCheckUtils]: 63: Hoare triple {2406#false} assume !false; {2406#false} is VALID [2022-04-08 13:23:59,574 INFO L134 CoverageAnalysis]: Checked inductivity of 135 backedges. 16 proven. 7 refuted. 0 times theorem prover too weak. 112 trivial. 0 not checked. [2022-04-08 13:23:59,574 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-08 13:24:08,333 INFO L290 TraceCheckUtils]: 63: Hoare triple {2406#false} assume !false; {2406#false} is VALID [2022-04-08 13:24:08,334 INFO L290 TraceCheckUtils]: 62: Hoare triple {2597#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {2406#false} is VALID [2022-04-08 13:24:08,334 INFO L290 TraceCheckUtils]: 61: Hoare triple {2593#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {2597#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:24:08,335 INFO L272 TraceCheckUtils]: 60: Hoare triple {2613#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {2593#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:24:08,335 INFO L290 TraceCheckUtils]: 59: Hoare triple {2613#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} assume !false; {2613#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:24:08,350 INFO L290 TraceCheckUtils]: 58: Hoare triple {2620#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {2613#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:24:08,370 INFO L290 TraceCheckUtils]: 57: Hoare triple {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {2620#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} is VALID [2022-04-08 13:24:08,371 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {2405#true} {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} #88#return; {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:24:08,371 INFO L290 TraceCheckUtils]: 55: Hoare triple {2405#true} assume true; {2405#true} is VALID [2022-04-08 13:24:08,371 INFO L290 TraceCheckUtils]: 54: Hoare triple {2405#true} assume !(0 == ~cond); {2405#true} is VALID [2022-04-08 13:24:08,371 INFO L290 TraceCheckUtils]: 53: Hoare triple {2405#true} ~cond := #in~cond; {2405#true} is VALID [2022-04-08 13:24:08,371 INFO L272 TraceCheckUtils]: 52: Hoare triple {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {2405#true} is VALID [2022-04-08 13:24:08,372 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {2405#true} {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} #86#return; {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:24:08,372 INFO L290 TraceCheckUtils]: 50: Hoare triple {2405#true} assume true; {2405#true} is VALID [2022-04-08 13:24:08,372 INFO L290 TraceCheckUtils]: 49: Hoare triple {2405#true} assume !(0 == ~cond); {2405#true} is VALID [2022-04-08 13:24:08,372 INFO L290 TraceCheckUtils]: 48: Hoare triple {2405#true} ~cond := #in~cond; {2405#true} is VALID [2022-04-08 13:24:08,372 INFO L272 TraceCheckUtils]: 47: Hoare triple {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {2405#true} is VALID [2022-04-08 13:24:08,373 INFO L290 TraceCheckUtils]: 46: Hoare triple {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} assume !false; {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:24:08,374 INFO L290 TraceCheckUtils]: 45: Hoare triple {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} assume !(~r~0 >= ~d~0); {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:24:08,375 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {2405#true} {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} #84#return; {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:24:08,375 INFO L290 TraceCheckUtils]: 43: Hoare triple {2405#true} assume true; {2405#true} is VALID [2022-04-08 13:24:08,375 INFO L290 TraceCheckUtils]: 42: Hoare triple {2405#true} assume !(0 == ~cond); {2405#true} is VALID [2022-04-08 13:24:08,375 INFO L290 TraceCheckUtils]: 41: Hoare triple {2405#true} ~cond := #in~cond; {2405#true} is VALID [2022-04-08 13:24:08,375 INFO L272 TraceCheckUtils]: 40: Hoare triple {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {2405#true} is VALID [2022-04-08 13:24:08,376 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {2405#true} {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} #82#return; {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:24:08,376 INFO L290 TraceCheckUtils]: 38: Hoare triple {2405#true} assume true; {2405#true} is VALID [2022-04-08 13:24:08,376 INFO L290 TraceCheckUtils]: 37: Hoare triple {2405#true} assume !(0 == ~cond); {2405#true} is VALID [2022-04-08 13:24:08,376 INFO L290 TraceCheckUtils]: 36: Hoare triple {2405#true} ~cond := #in~cond; {2405#true} is VALID [2022-04-08 13:24:08,376 INFO L272 TraceCheckUtils]: 35: Hoare triple {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {2405#true} is VALID [2022-04-08 13:24:08,377 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {2405#true} {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} #80#return; {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:24:08,377 INFO L290 TraceCheckUtils]: 33: Hoare triple {2405#true} assume true; {2405#true} is VALID [2022-04-08 13:24:08,377 INFO L290 TraceCheckUtils]: 32: Hoare triple {2405#true} assume !(0 == ~cond); {2405#true} is VALID [2022-04-08 13:24:08,377 INFO L290 TraceCheckUtils]: 31: Hoare triple {2405#true} ~cond := #in~cond; {2405#true} is VALID [2022-04-08 13:24:08,377 INFO L272 TraceCheckUtils]: 30: Hoare triple {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {2405#true} is VALID [2022-04-08 13:24:08,378 INFO L290 TraceCheckUtils]: 29: Hoare triple {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} assume !false; {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:24:08,384 INFO L290 TraceCheckUtils]: 28: Hoare triple {2620#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {2624#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:24:08,385 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {2405#true} {2620#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} #84#return; {2620#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} is VALID [2022-04-08 13:24:08,385 INFO L290 TraceCheckUtils]: 26: Hoare triple {2405#true} assume true; {2405#true} is VALID [2022-04-08 13:24:08,385 INFO L290 TraceCheckUtils]: 25: Hoare triple {2405#true} assume !(0 == ~cond); {2405#true} is VALID [2022-04-08 13:24:08,385 INFO L290 TraceCheckUtils]: 24: Hoare triple {2405#true} ~cond := #in~cond; {2405#true} is VALID [2022-04-08 13:24:08,385 INFO L272 TraceCheckUtils]: 23: Hoare triple {2620#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {2405#true} is VALID [2022-04-08 13:24:08,386 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {2405#true} {2620#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} #82#return; {2620#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} is VALID [2022-04-08 13:24:08,387 INFO L290 TraceCheckUtils]: 21: Hoare triple {2405#true} assume true; {2405#true} is VALID [2022-04-08 13:24:08,387 INFO L290 TraceCheckUtils]: 20: Hoare triple {2405#true} assume !(0 == ~cond); {2405#true} is VALID [2022-04-08 13:24:08,387 INFO L290 TraceCheckUtils]: 19: Hoare triple {2405#true} ~cond := #in~cond; {2405#true} is VALID [2022-04-08 13:24:08,387 INFO L272 TraceCheckUtils]: 18: Hoare triple {2620#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {2405#true} is VALID [2022-04-08 13:24:08,387 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {2405#true} {2620#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} #80#return; {2620#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} is VALID [2022-04-08 13:24:08,387 INFO L290 TraceCheckUtils]: 16: Hoare triple {2405#true} assume true; {2405#true} is VALID [2022-04-08 13:24:08,388 INFO L290 TraceCheckUtils]: 15: Hoare triple {2405#true} assume !(0 == ~cond); {2405#true} is VALID [2022-04-08 13:24:08,388 INFO L290 TraceCheckUtils]: 14: Hoare triple {2405#true} ~cond := #in~cond; {2405#true} is VALID [2022-04-08 13:24:08,388 INFO L272 TraceCheckUtils]: 13: Hoare triple {2620#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {2405#true} is VALID [2022-04-08 13:24:08,388 INFO L290 TraceCheckUtils]: 12: Hoare triple {2620#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} assume !false; {2620#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} is VALID [2022-04-08 13:24:08,388 INFO L290 TraceCheckUtils]: 11: Hoare triple {2405#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {2620#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} is VALID [2022-04-08 13:24:08,388 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {2405#true} {2405#true} #78#return; {2405#true} is VALID [2022-04-08 13:24:08,389 INFO L290 TraceCheckUtils]: 9: Hoare triple {2405#true} assume true; {2405#true} is VALID [2022-04-08 13:24:08,389 INFO L290 TraceCheckUtils]: 8: Hoare triple {2405#true} assume !(0 == ~cond); {2405#true} is VALID [2022-04-08 13:24:08,389 INFO L290 TraceCheckUtils]: 7: Hoare triple {2405#true} ~cond := #in~cond; {2405#true} is VALID [2022-04-08 13:24:08,389 INFO L272 TraceCheckUtils]: 6: Hoare triple {2405#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {2405#true} is VALID [2022-04-08 13:24:08,389 INFO L290 TraceCheckUtils]: 5: Hoare triple {2405#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {2405#true} is VALID [2022-04-08 13:24:08,389 INFO L272 TraceCheckUtils]: 4: Hoare triple {2405#true} call #t~ret5 := main(); {2405#true} is VALID [2022-04-08 13:24:08,389 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {2405#true} {2405#true} #94#return; {2405#true} is VALID [2022-04-08 13:24:08,389 INFO L290 TraceCheckUtils]: 2: Hoare triple {2405#true} assume true; {2405#true} is VALID [2022-04-08 13:24:08,389 INFO L290 TraceCheckUtils]: 1: Hoare triple {2405#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {2405#true} is VALID [2022-04-08 13:24:08,389 INFO L272 TraceCheckUtils]: 0: Hoare triple {2405#true} call ULTIMATE.init(); {2405#true} is VALID [2022-04-08 13:24:08,390 INFO L134 CoverageAnalysis]: Checked inductivity of 135 backedges. 16 proven. 7 refuted. 0 times theorem prover too weak. 112 trivial. 0 not checked. [2022-04-08 13:24:08,390 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-08 13:24:08,390 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [119658855] [2022-04-08 13:24:08,390 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-08 13:24:08,390 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1876775598] [2022-04-08 13:24:08,390 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1876775598] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-08 13:24:08,390 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-08 13:24:08,390 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [7, 7] total 10 [2022-04-08 13:24:08,390 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-08 13:24:08,390 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [703335374] [2022-04-08 13:24:08,390 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [703335374] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:24:08,390 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:24:08,390 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [7] imperfect sequences [] total 7 [2022-04-08 13:24:08,390 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [206098667] [2022-04-08 13:24:08,391 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-08 13:24:08,391 INFO L78 Accepts]: Start accepts. Automaton has has 7 states, 7 states have (on average 3.0) internal successors, (21), 6 states have internal predecessors, (21), 4 states have call successors, (12), 2 states have call predecessors, (12), 1 states have return successors, (10), 3 states have call predecessors, (10), 3 states have call successors, (10) Word has length 64 [2022-04-08 13:24:08,391 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-08 13:24:08,391 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 7 states, 7 states have (on average 3.0) internal successors, (21), 6 states have internal predecessors, (21), 4 states have call successors, (12), 2 states have call predecessors, (12), 1 states have return successors, (10), 3 states have call predecessors, (10), 3 states have call successors, (10) [2022-04-08 13:24:08,424 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 43 edges. 43 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:24:08,425 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 7 states [2022-04-08 13:24:08,425 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-08 13:24:08,425 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 7 interpolants. [2022-04-08 13:24:08,425 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=24, Invalid=66, Unknown=0, NotChecked=0, Total=90 [2022-04-08 13:24:08,425 INFO L87 Difference]: Start difference. First operand 64 states and 77 transitions. Second operand has 7 states, 7 states have (on average 3.0) internal successors, (21), 6 states have internal predecessors, (21), 4 states have call successors, (12), 2 states have call predecessors, (12), 1 states have return successors, (10), 3 states have call predecessors, (10), 3 states have call successors, (10) [2022-04-08 13:24:09,003 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:24:09,005 INFO L93 Difference]: Finished difference Result 130 states and 164 transitions. [2022-04-08 13:24:09,005 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 7 states. [2022-04-08 13:24:09,005 INFO L78 Accepts]: Start accepts. Automaton has has 7 states, 7 states have (on average 3.0) internal successors, (21), 6 states have internal predecessors, (21), 4 states have call successors, (12), 2 states have call predecessors, (12), 1 states have return successors, (10), 3 states have call predecessors, (10), 3 states have call successors, (10) Word has length 64 [2022-04-08 13:24:09,005 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-08 13:24:09,006 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 7 states, 7 states have (on average 3.0) internal successors, (21), 6 states have internal predecessors, (21), 4 states have call successors, (12), 2 states have call predecessors, (12), 1 states have return successors, (10), 3 states have call predecessors, (10), 3 states have call successors, (10) [2022-04-08 13:24:09,008 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 7 states to 7 states and 107 transitions. [2022-04-08 13:24:09,009 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 7 states, 7 states have (on average 3.0) internal successors, (21), 6 states have internal predecessors, (21), 4 states have call successors, (12), 2 states have call predecessors, (12), 1 states have return successors, (10), 3 states have call predecessors, (10), 3 states have call successors, (10) [2022-04-08 13:24:09,010 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 7 states to 7 states and 107 transitions. [2022-04-08 13:24:09,010 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 7 states and 107 transitions. [2022-04-08 13:24:09,092 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 107 edges. 107 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:24:09,094 INFO L225 Difference]: With dead ends: 130 [2022-04-08 13:24:09,094 INFO L226 Difference]: Without dead ends: 101 [2022-04-08 13:24:09,095 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 128 GetRequests, 116 SyntacticMatches, 3 SemanticMatches, 9 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 3 ImplicationChecksByTransitivity, 0.1s TimeCoverageRelationStatistics Valid=28, Invalid=82, Unknown=0, NotChecked=0, Total=110 [2022-04-08 13:24:09,095 INFO L913 BasicCegarLoop]: 46 mSDtfsCounter, 11 mSDsluCounter, 126 mSDsCounter, 0 mSdLazyCounter, 208 mSolverCounterSat, 14 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.2s Time, 0 mProtectedPredicate, 0 mProtectedAction, 17 SdHoareTripleChecker+Valid, 172 SdHoareTripleChecker+Invalid, 222 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 14 IncrementalHoareTripleChecker+Valid, 208 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.2s IncrementalHoareTripleChecker+Time [2022-04-08 13:24:09,095 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [17 Valid, 172 Invalid, 222 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [14 Valid, 208 Invalid, 0 Unknown, 0 Unchecked, 0.2s Time] [2022-04-08 13:24:09,096 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 101 states. [2022-04-08 13:24:09,138 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 101 to 99. [2022-04-08 13:24:09,138 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-08 13:24:09,138 INFO L82 GeneralOperation]: Start isEquivalent. First operand 101 states. Second operand has 99 states, 60 states have (on average 1.15) internal successors, (69), 63 states have internal predecessors, (69), 25 states have call successors, (25), 14 states have call predecessors, (25), 13 states have return successors, (23), 21 states have call predecessors, (23), 23 states have call successors, (23) [2022-04-08 13:24:09,139 INFO L74 IsIncluded]: Start isIncluded. First operand 101 states. Second operand has 99 states, 60 states have (on average 1.15) internal successors, (69), 63 states have internal predecessors, (69), 25 states have call successors, (25), 14 states have call predecessors, (25), 13 states have return successors, (23), 21 states have call predecessors, (23), 23 states have call successors, (23) [2022-04-08 13:24:09,139 INFO L87 Difference]: Start difference. First operand 101 states. Second operand has 99 states, 60 states have (on average 1.15) internal successors, (69), 63 states have internal predecessors, (69), 25 states have call successors, (25), 14 states have call predecessors, (25), 13 states have return successors, (23), 21 states have call predecessors, (23), 23 states have call successors, (23) [2022-04-08 13:24:09,142 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:24:09,142 INFO L93 Difference]: Finished difference Result 101 states and 120 transitions. [2022-04-08 13:24:09,142 INFO L276 IsEmpty]: Start isEmpty. Operand 101 states and 120 transitions. [2022-04-08 13:24:09,143 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:24:09,143 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:24:09,144 INFO L74 IsIncluded]: Start isIncluded. First operand has 99 states, 60 states have (on average 1.15) internal successors, (69), 63 states have internal predecessors, (69), 25 states have call successors, (25), 14 states have call predecessors, (25), 13 states have return successors, (23), 21 states have call predecessors, (23), 23 states have call successors, (23) Second operand 101 states. [2022-04-08 13:24:09,144 INFO L87 Difference]: Start difference. First operand has 99 states, 60 states have (on average 1.15) internal successors, (69), 63 states have internal predecessors, (69), 25 states have call successors, (25), 14 states have call predecessors, (25), 13 states have return successors, (23), 21 states have call predecessors, (23), 23 states have call successors, (23) Second operand 101 states. [2022-04-08 13:24:09,148 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:24:09,148 INFO L93 Difference]: Finished difference Result 101 states and 120 transitions. [2022-04-08 13:24:09,148 INFO L276 IsEmpty]: Start isEmpty. Operand 101 states and 120 transitions. [2022-04-08 13:24:09,148 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:24:09,148 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:24:09,148 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-08 13:24:09,148 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-08 13:24:09,149 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 99 states, 60 states have (on average 1.15) internal successors, (69), 63 states have internal predecessors, (69), 25 states have call successors, (25), 14 states have call predecessors, (25), 13 states have return successors, (23), 21 states have call predecessors, (23), 23 states have call successors, (23) [2022-04-08 13:24:09,151 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 99 states to 99 states and 117 transitions. [2022-04-08 13:24:09,151 INFO L78 Accepts]: Start accepts. Automaton has 99 states and 117 transitions. Word has length 64 [2022-04-08 13:24:09,151 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-08 13:24:09,152 INFO L478 AbstractCegarLoop]: Abstraction has 99 states and 117 transitions. [2022-04-08 13:24:09,152 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 7 states, 7 states have (on average 3.0) internal successors, (21), 6 states have internal predecessors, (21), 4 states have call successors, (12), 2 states have call predecessors, (12), 1 states have return successors, (10), 3 states have call predecessors, (10), 3 states have call successors, (10) [2022-04-08 13:24:09,152 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 99 states and 117 transitions. [2022-04-08 13:24:09,275 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 117 edges. 117 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:24:09,275 INFO L276 IsEmpty]: Start isEmpty. Operand 99 states and 117 transitions. [2022-04-08 13:24:09,276 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 70 [2022-04-08 13:24:09,276 INFO L491 BasicCegarLoop]: Found error trace [2022-04-08 13:24:09,276 INFO L499 BasicCegarLoop]: trace histogram [10, 9, 9, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-08 13:24:09,293 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (5)] Forceful destruction successful, exit code 0 [2022-04-08 13:24:09,483 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable6,5 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:24:09,483 INFO L403 AbstractCegarLoop]: === Iteration 8 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-08 13:24:09,484 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-08 13:24:09,484 INFO L85 PathProgramCache]: Analyzing trace with hash -262609796, now seen corresponding path program 3 times [2022-04-08 13:24:09,484 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-08 13:24:09,484 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [1668396252] [2022-04-08 13:24:13,589 INFO L97 AcceleratorQvasr]: Qvasr could not accelerate loop because java.lang.UnsupportedOperationException: Cannot deal with arrays. [2022-04-08 13:24:13,589 INFO L274 tedInterpolationCore]: Could not compute an accelerate. [2022-04-08 13:24:13,589 INFO L85 PathProgramCache]: Analyzing trace with hash -262609796, now seen corresponding path program 4 times [2022-04-08 13:24:13,589 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-08 13:24:13,589 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [865059084] [2022-04-08 13:24:13,589 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-08 13:24:13,589 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-08 13:24:13,614 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-08 13:24:13,614 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1388080004] [2022-04-08 13:24:13,614 INFO L93 rtionOrderModulation]: Changing assertion order to TERMS_WITH_SMALL_CONSTANTS_FIRST [2022-04-08 13:24:13,614 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:24:13,614 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-08 13:24:13,620 INFO L229 MonitoredProcess]: Starting monitored process 6 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-08 13:24:13,622 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (6)] Waiting until timeout for monitored process [2022-04-08 13:24:13,663 INFO L228 tOrderPrioritization]: Assert order TERMS_WITH_SMALL_CONSTANTS_FIRST issued 0 check-sat command(s) [2022-04-08 13:24:13,663 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-08 13:24:13,664 INFO L263 TraceCheckSpWp]: Trace formula consists of 141 conjuncts, 17 conjunts are in the unsatisfiable core [2022-04-08 13:24:13,678 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:24:13,681 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-08 13:24:13,989 INFO L272 TraceCheckUtils]: 0: Hoare triple {3460#true} call ULTIMATE.init(); {3460#true} is VALID [2022-04-08 13:24:13,989 INFO L290 TraceCheckUtils]: 1: Hoare triple {3460#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {3460#true} is VALID [2022-04-08 13:24:13,989 INFO L290 TraceCheckUtils]: 2: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:13,989 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3460#true} {3460#true} #94#return; {3460#true} is VALID [2022-04-08 13:24:13,989 INFO L272 TraceCheckUtils]: 4: Hoare triple {3460#true} call #t~ret5 := main(); {3460#true} is VALID [2022-04-08 13:24:13,989 INFO L290 TraceCheckUtils]: 5: Hoare triple {3460#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {3460#true} is VALID [2022-04-08 13:24:13,989 INFO L272 TraceCheckUtils]: 6: Hoare triple {3460#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {3460#true} is VALID [2022-04-08 13:24:13,989 INFO L290 TraceCheckUtils]: 7: Hoare triple {3460#true} ~cond := #in~cond; {3460#true} is VALID [2022-04-08 13:24:13,990 INFO L290 TraceCheckUtils]: 8: Hoare triple {3460#true} assume !(0 == ~cond); {3460#true} is VALID [2022-04-08 13:24:13,990 INFO L290 TraceCheckUtils]: 9: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:13,990 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {3460#true} {3460#true} #78#return; {3460#true} is VALID [2022-04-08 13:24:13,990 INFO L290 TraceCheckUtils]: 11: Hoare triple {3460#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:24:13,991 INFO L290 TraceCheckUtils]: 12: Hoare triple {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !false; {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:24:13,991 INFO L272 TraceCheckUtils]: 13: Hoare triple {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {3460#true} is VALID [2022-04-08 13:24:13,991 INFO L290 TraceCheckUtils]: 14: Hoare triple {3460#true} ~cond := #in~cond; {3460#true} is VALID [2022-04-08 13:24:13,991 INFO L290 TraceCheckUtils]: 15: Hoare triple {3460#true} assume !(0 == ~cond); {3460#true} is VALID [2022-04-08 13:24:13,991 INFO L290 TraceCheckUtils]: 16: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:13,991 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {3460#true} {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #80#return; {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:24:13,992 INFO L272 TraceCheckUtils]: 18: Hoare triple {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {3460#true} is VALID [2022-04-08 13:24:13,992 INFO L290 TraceCheckUtils]: 19: Hoare triple {3460#true} ~cond := #in~cond; {3460#true} is VALID [2022-04-08 13:24:13,992 INFO L290 TraceCheckUtils]: 20: Hoare triple {3460#true} assume !(0 == ~cond); {3460#true} is VALID [2022-04-08 13:24:13,992 INFO L290 TraceCheckUtils]: 21: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:13,992 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {3460#true} {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #82#return; {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:24:13,992 INFO L272 TraceCheckUtils]: 23: Hoare triple {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {3460#true} is VALID [2022-04-08 13:24:13,993 INFO L290 TraceCheckUtils]: 24: Hoare triple {3460#true} ~cond := #in~cond; {3460#true} is VALID [2022-04-08 13:24:13,993 INFO L290 TraceCheckUtils]: 25: Hoare triple {3460#true} assume !(0 == ~cond); {3460#true} is VALID [2022-04-08 13:24:13,993 INFO L290 TraceCheckUtils]: 26: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:13,993 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {3460#true} {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #84#return; {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:24:13,994 INFO L290 TraceCheckUtils]: 28: Hoare triple {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:24:13,994 INFO L290 TraceCheckUtils]: 29: Hoare triple {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} assume !false; {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:24:13,994 INFO L272 TraceCheckUtils]: 30: Hoare triple {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {3460#true} is VALID [2022-04-08 13:24:13,994 INFO L290 TraceCheckUtils]: 31: Hoare triple {3460#true} ~cond := #in~cond; {3460#true} is VALID [2022-04-08 13:24:13,994 INFO L290 TraceCheckUtils]: 32: Hoare triple {3460#true} assume !(0 == ~cond); {3460#true} is VALID [2022-04-08 13:24:13,994 INFO L290 TraceCheckUtils]: 33: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:13,995 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {3460#true} {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} #80#return; {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:24:13,995 INFO L272 TraceCheckUtils]: 35: Hoare triple {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {3460#true} is VALID [2022-04-08 13:24:13,995 INFO L290 TraceCheckUtils]: 36: Hoare triple {3460#true} ~cond := #in~cond; {3460#true} is VALID [2022-04-08 13:24:13,995 INFO L290 TraceCheckUtils]: 37: Hoare triple {3460#true} assume !(0 == ~cond); {3460#true} is VALID [2022-04-08 13:24:13,995 INFO L290 TraceCheckUtils]: 38: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:13,996 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {3460#true} {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} #82#return; {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:24:13,996 INFO L272 TraceCheckUtils]: 40: Hoare triple {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {3460#true} is VALID [2022-04-08 13:24:13,996 INFO L290 TraceCheckUtils]: 41: Hoare triple {3460#true} ~cond := #in~cond; {3460#true} is VALID [2022-04-08 13:24:13,996 INFO L290 TraceCheckUtils]: 42: Hoare triple {3460#true} assume !(0 == ~cond); {3460#true} is VALID [2022-04-08 13:24:13,996 INFO L290 TraceCheckUtils]: 43: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:13,996 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {3460#true} {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} #84#return; {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:24:13,997 INFO L290 TraceCheckUtils]: 45: Hoare triple {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} assume !(~r~0 >= ~d~0); {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:24:13,997 INFO L290 TraceCheckUtils]: 46: Hoare triple {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} assume !false; {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:24:13,997 INFO L272 TraceCheckUtils]: 47: Hoare triple {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {3460#true} is VALID [2022-04-08 13:24:13,997 INFO L290 TraceCheckUtils]: 48: Hoare triple {3460#true} ~cond := #in~cond; {3460#true} is VALID [2022-04-08 13:24:13,997 INFO L290 TraceCheckUtils]: 49: Hoare triple {3460#true} assume !(0 == ~cond); {3460#true} is VALID [2022-04-08 13:24:13,997 INFO L290 TraceCheckUtils]: 50: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:13,998 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {3460#true} {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} #86#return; {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:24:13,998 INFO L272 TraceCheckUtils]: 52: Hoare triple {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {3460#true} is VALID [2022-04-08 13:24:13,998 INFO L290 TraceCheckUtils]: 53: Hoare triple {3460#true} ~cond := #in~cond; {3460#true} is VALID [2022-04-08 13:24:13,998 INFO L290 TraceCheckUtils]: 54: Hoare triple {3460#true} assume !(0 == ~cond); {3460#true} is VALID [2022-04-08 13:24:13,998 INFO L290 TraceCheckUtils]: 55: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:13,999 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {3460#true} {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} #88#return; {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:24:13,999 INFO L290 TraceCheckUtils]: 57: Hoare triple {3550#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:24:13,999 INFO L290 TraceCheckUtils]: 58: Hoare triple {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:24:14,000 INFO L290 TraceCheckUtils]: 59: Hoare triple {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !false; {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:24:14,000 INFO L272 TraceCheckUtils]: 60: Hoare triple {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {3460#true} is VALID [2022-04-08 13:24:14,000 INFO L290 TraceCheckUtils]: 61: Hoare triple {3460#true} ~cond := #in~cond; {3460#true} is VALID [2022-04-08 13:24:14,000 INFO L290 TraceCheckUtils]: 62: Hoare triple {3460#true} assume !(0 == ~cond); {3460#true} is VALID [2022-04-08 13:24:14,000 INFO L290 TraceCheckUtils]: 63: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:14,001 INFO L284 TraceCheckUtils]: 64: Hoare quadruple {3460#true} {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #86#return; {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:24:14,001 INFO L272 TraceCheckUtils]: 65: Hoare triple {3498#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {3662#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:24:14,002 INFO L290 TraceCheckUtils]: 66: Hoare triple {3662#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {3666#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:24:14,002 INFO L290 TraceCheckUtils]: 67: Hoare triple {3666#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {3461#false} is VALID [2022-04-08 13:24:14,002 INFO L290 TraceCheckUtils]: 68: Hoare triple {3461#false} assume !false; {3461#false} is VALID [2022-04-08 13:24:14,002 INFO L134 CoverageAnalysis]: Checked inductivity of 170 backedges. 18 proven. 8 refuted. 0 times theorem prover too weak. 144 trivial. 0 not checked. [2022-04-08 13:24:14,002 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-08 13:24:20,682 INFO L290 TraceCheckUtils]: 68: Hoare triple {3461#false} assume !false; {3461#false} is VALID [2022-04-08 13:24:20,683 INFO L290 TraceCheckUtils]: 67: Hoare triple {3666#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {3461#false} is VALID [2022-04-08 13:24:20,683 INFO L290 TraceCheckUtils]: 66: Hoare triple {3662#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {3666#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:24:20,683 INFO L272 TraceCheckUtils]: 65: Hoare triple {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {3662#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:24:20,684 INFO L284 TraceCheckUtils]: 64: Hoare quadruple {3460#true} {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} #86#return; {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:24:20,684 INFO L290 TraceCheckUtils]: 63: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:20,684 INFO L290 TraceCheckUtils]: 62: Hoare triple {3460#true} assume !(0 == ~cond); {3460#true} is VALID [2022-04-08 13:24:20,684 INFO L290 TraceCheckUtils]: 61: Hoare triple {3460#true} ~cond := #in~cond; {3460#true} is VALID [2022-04-08 13:24:20,684 INFO L272 TraceCheckUtils]: 60: Hoare triple {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {3460#true} is VALID [2022-04-08 13:24:20,685 INFO L290 TraceCheckUtils]: 59: Hoare triple {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} assume !false; {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:24:20,685 INFO L290 TraceCheckUtils]: 58: Hoare triple {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:24:20,698 INFO L290 TraceCheckUtils]: 57: Hoare triple {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:24:20,698 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {3460#true} {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} #88#return; {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} is VALID [2022-04-08 13:24:20,699 INFO L290 TraceCheckUtils]: 55: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:20,699 INFO L290 TraceCheckUtils]: 54: Hoare triple {3460#true} assume !(0 == ~cond); {3460#true} is VALID [2022-04-08 13:24:20,699 INFO L290 TraceCheckUtils]: 53: Hoare triple {3460#true} ~cond := #in~cond; {3460#true} is VALID [2022-04-08 13:24:20,699 INFO L272 TraceCheckUtils]: 52: Hoare triple {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {3460#true} is VALID [2022-04-08 13:24:20,699 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {3460#true} {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} #86#return; {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} is VALID [2022-04-08 13:24:20,699 INFO L290 TraceCheckUtils]: 50: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:20,699 INFO L290 TraceCheckUtils]: 49: Hoare triple {3460#true} assume !(0 == ~cond); {3460#true} is VALID [2022-04-08 13:24:20,700 INFO L290 TraceCheckUtils]: 48: Hoare triple {3460#true} ~cond := #in~cond; {3460#true} is VALID [2022-04-08 13:24:20,700 INFO L272 TraceCheckUtils]: 47: Hoare triple {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {3460#true} is VALID [2022-04-08 13:24:20,700 INFO L290 TraceCheckUtils]: 46: Hoare triple {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} assume !false; {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} is VALID [2022-04-08 13:24:20,701 INFO L290 TraceCheckUtils]: 45: Hoare triple {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} assume !(~r~0 >= ~d~0); {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} is VALID [2022-04-08 13:24:20,702 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {3460#true} {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} #84#return; {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} is VALID [2022-04-08 13:24:20,702 INFO L290 TraceCheckUtils]: 43: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:20,702 INFO L290 TraceCheckUtils]: 42: Hoare triple {3460#true} assume !(0 == ~cond); {3460#true} is VALID [2022-04-08 13:24:20,702 INFO L290 TraceCheckUtils]: 41: Hoare triple {3460#true} ~cond := #in~cond; {3460#true} is VALID [2022-04-08 13:24:20,702 INFO L272 TraceCheckUtils]: 40: Hoare triple {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {3460#true} is VALID [2022-04-08 13:24:20,702 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {3460#true} {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} #82#return; {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} is VALID [2022-04-08 13:24:20,702 INFO L290 TraceCheckUtils]: 38: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:20,703 INFO L290 TraceCheckUtils]: 37: Hoare triple {3460#true} assume !(0 == ~cond); {3460#true} is VALID [2022-04-08 13:24:20,703 INFO L290 TraceCheckUtils]: 36: Hoare triple {3460#true} ~cond := #in~cond; {3460#true} is VALID [2022-04-08 13:24:20,703 INFO L272 TraceCheckUtils]: 35: Hoare triple {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {3460#true} is VALID [2022-04-08 13:24:20,703 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {3460#true} {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} #80#return; {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} is VALID [2022-04-08 13:24:20,703 INFO L290 TraceCheckUtils]: 33: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:20,703 INFO L290 TraceCheckUtils]: 32: Hoare triple {3460#true} assume !(0 == ~cond); {3460#true} is VALID [2022-04-08 13:24:20,703 INFO L290 TraceCheckUtils]: 31: Hoare triple {3460#true} ~cond := #in~cond; {3460#true} is VALID [2022-04-08 13:24:20,703 INFO L272 TraceCheckUtils]: 30: Hoare triple {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {3460#true} is VALID [2022-04-08 13:24:20,705 INFO L290 TraceCheckUtils]: 29: Hoare triple {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} assume !false; {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} is VALID [2022-04-08 13:24:20,710 INFO L290 TraceCheckUtils]: 28: Hoare triple {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {3707#(and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1)))))))} is VALID [2022-04-08 13:24:20,710 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {3460#true} {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} #84#return; {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:24:20,710 INFO L290 TraceCheckUtils]: 26: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:20,711 INFO L290 TraceCheckUtils]: 25: Hoare triple {3460#true} assume !(0 == ~cond); {3460#true} is VALID [2022-04-08 13:24:20,711 INFO L290 TraceCheckUtils]: 24: Hoare triple {3460#true} ~cond := #in~cond; {3460#true} is VALID [2022-04-08 13:24:20,711 INFO L272 TraceCheckUtils]: 23: Hoare triple {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {3460#true} is VALID [2022-04-08 13:24:20,711 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {3460#true} {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} #82#return; {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:24:20,711 INFO L290 TraceCheckUtils]: 21: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:20,711 INFO L290 TraceCheckUtils]: 20: Hoare triple {3460#true} assume !(0 == ~cond); {3460#true} is VALID [2022-04-08 13:24:20,712 INFO L290 TraceCheckUtils]: 19: Hoare triple {3460#true} ~cond := #in~cond; {3460#true} is VALID [2022-04-08 13:24:20,712 INFO L272 TraceCheckUtils]: 18: Hoare triple {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {3460#true} is VALID [2022-04-08 13:24:20,712 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {3460#true} {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} #80#return; {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:24:20,712 INFO L290 TraceCheckUtils]: 16: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:20,712 INFO L290 TraceCheckUtils]: 15: Hoare triple {3460#true} assume !(0 == ~cond); {3460#true} is VALID [2022-04-08 13:24:20,712 INFO L290 TraceCheckUtils]: 14: Hoare triple {3460#true} ~cond := #in~cond; {3460#true} is VALID [2022-04-08 13:24:20,712 INFO L272 TraceCheckUtils]: 13: Hoare triple {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {3460#true} is VALID [2022-04-08 13:24:20,713 INFO L290 TraceCheckUtils]: 12: Hoare triple {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} assume !false; {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:24:20,713 INFO L290 TraceCheckUtils]: 11: Hoare triple {3460#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {3682#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:24:20,713 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {3460#true} {3460#true} #78#return; {3460#true} is VALID [2022-04-08 13:24:20,713 INFO L290 TraceCheckUtils]: 9: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:20,713 INFO L290 TraceCheckUtils]: 8: Hoare triple {3460#true} assume !(0 == ~cond); {3460#true} is VALID [2022-04-08 13:24:20,713 INFO L290 TraceCheckUtils]: 7: Hoare triple {3460#true} ~cond := #in~cond; {3460#true} is VALID [2022-04-08 13:24:20,713 INFO L272 TraceCheckUtils]: 6: Hoare triple {3460#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {3460#true} is VALID [2022-04-08 13:24:20,714 INFO L290 TraceCheckUtils]: 5: Hoare triple {3460#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {3460#true} is VALID [2022-04-08 13:24:20,714 INFO L272 TraceCheckUtils]: 4: Hoare triple {3460#true} call #t~ret5 := main(); {3460#true} is VALID [2022-04-08 13:24:20,714 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3460#true} {3460#true} #94#return; {3460#true} is VALID [2022-04-08 13:24:20,714 INFO L290 TraceCheckUtils]: 2: Hoare triple {3460#true} assume true; {3460#true} is VALID [2022-04-08 13:24:20,714 INFO L290 TraceCheckUtils]: 1: Hoare triple {3460#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {3460#true} is VALID [2022-04-08 13:24:20,714 INFO L272 TraceCheckUtils]: 0: Hoare triple {3460#true} call ULTIMATE.init(); {3460#true} is VALID [2022-04-08 13:24:20,714 INFO L134 CoverageAnalysis]: Checked inductivity of 170 backedges. 18 proven. 8 refuted. 0 times theorem prover too weak. 144 trivial. 0 not checked. [2022-04-08 13:24:20,714 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-08 13:24:20,714 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [865059084] [2022-04-08 13:24:20,714 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-08 13:24:20,714 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1388080004] [2022-04-08 13:24:20,715 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1388080004] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-08 13:24:20,715 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-08 13:24:20,715 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [6, 6] total 8 [2022-04-08 13:24:20,715 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-08 13:24:20,715 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [1668396252] [2022-04-08 13:24:20,715 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [1668396252] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:24:20,715 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:24:20,715 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [6] imperfect sequences [] total 6 [2022-04-08 13:24:20,715 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1014813508] [2022-04-08 13:24:20,715 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-08 13:24:20,716 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 3.5) internal successors, (21), 5 states have internal predecessors, (21), 3 states have call successors, (13), 2 states have call predecessors, (13), 1 states have return successors, (11), 3 states have call predecessors, (11), 3 states have call successors, (11) Word has length 69 [2022-04-08 13:24:20,716 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-08 13:24:20,716 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 6 states, 6 states have (on average 3.5) internal successors, (21), 5 states have internal predecessors, (21), 3 states have call successors, (13), 2 states have call predecessors, (13), 1 states have return successors, (11), 3 states have call predecessors, (11), 3 states have call successors, (11) [2022-04-08 13:24:20,752 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 45 edges. 45 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:24:20,753 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 6 states [2022-04-08 13:24:20,753 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-08 13:24:20,753 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 6 interpolants. [2022-04-08 13:24:20,753 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=17, Invalid=39, Unknown=0, NotChecked=0, Total=56 [2022-04-08 13:24:20,753 INFO L87 Difference]: Start difference. First operand 99 states and 117 transitions. Second operand has 6 states, 6 states have (on average 3.5) internal successors, (21), 5 states have internal predecessors, (21), 3 states have call successors, (13), 2 states have call predecessors, (13), 1 states have return successors, (11), 3 states have call predecessors, (11), 3 states have call successors, (11) [2022-04-08 13:24:21,051 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:24:21,051 INFO L93 Difference]: Finished difference Result 126 states and 151 transitions. [2022-04-08 13:24:21,051 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 6 states. [2022-04-08 13:24:21,051 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 3.5) internal successors, (21), 5 states have internal predecessors, (21), 3 states have call successors, (13), 2 states have call predecessors, (13), 1 states have return successors, (11), 3 states have call predecessors, (11), 3 states have call successors, (11) Word has length 69 [2022-04-08 13:24:21,051 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-08 13:24:21,051 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 3.5) internal successors, (21), 5 states have internal predecessors, (21), 3 states have call successors, (13), 2 states have call predecessors, (13), 1 states have return successors, (11), 3 states have call predecessors, (11), 3 states have call successors, (11) [2022-04-08 13:24:21,053 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 6 states to 6 states and 93 transitions. [2022-04-08 13:24:21,053 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 3.5) internal successors, (21), 5 states have internal predecessors, (21), 3 states have call successors, (13), 2 states have call predecessors, (13), 1 states have return successors, (11), 3 states have call predecessors, (11), 3 states have call successors, (11) [2022-04-08 13:24:21,054 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 6 states to 6 states and 93 transitions. [2022-04-08 13:24:21,054 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 6 states and 93 transitions. [2022-04-08 13:24:21,115 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 93 edges. 93 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:24:21,118 INFO L225 Difference]: With dead ends: 126 [2022-04-08 13:24:21,118 INFO L226 Difference]: Without dead ends: 103 [2022-04-08 13:24:21,119 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 138 GetRequests, 129 SyntacticMatches, 2 SemanticMatches, 7 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.2s TimeCoverageRelationStatistics Valid=21, Invalid=51, Unknown=0, NotChecked=0, Total=72 [2022-04-08 13:24:21,119 INFO L913 BasicCegarLoop]: 48 mSDtfsCounter, 6 mSDsluCounter, 127 mSDsCounter, 0 mSdLazyCounter, 101 mSolverCounterSat, 5 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.1s Time, 0 mProtectedPredicate, 0 mProtectedAction, 8 SdHoareTripleChecker+Valid, 175 SdHoareTripleChecker+Invalid, 106 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 5 IncrementalHoareTripleChecker+Valid, 101 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.1s IncrementalHoareTripleChecker+Time [2022-04-08 13:24:21,119 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [8 Valid, 175 Invalid, 106 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [5 Valid, 101 Invalid, 0 Unknown, 0 Unchecked, 0.1s Time] [2022-04-08 13:24:21,120 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 103 states. [2022-04-08 13:24:21,163 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 103 to 103. [2022-04-08 13:24:21,163 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-08 13:24:21,163 INFO L82 GeneralOperation]: Start isEquivalent. First operand 103 states. Second operand has 103 states, 62 states have (on average 1.1129032258064515) internal successors, (69), 66 states have internal predecessors, (69), 26 states have call successors, (26), 15 states have call predecessors, (26), 14 states have return successors, (23), 21 states have call predecessors, (23), 23 states have call successors, (23) [2022-04-08 13:24:21,163 INFO L74 IsIncluded]: Start isIncluded. First operand 103 states. Second operand has 103 states, 62 states have (on average 1.1129032258064515) internal successors, (69), 66 states have internal predecessors, (69), 26 states have call successors, (26), 15 states have call predecessors, (26), 14 states have return successors, (23), 21 states have call predecessors, (23), 23 states have call successors, (23) [2022-04-08 13:24:21,164 INFO L87 Difference]: Start difference. First operand 103 states. Second operand has 103 states, 62 states have (on average 1.1129032258064515) internal successors, (69), 66 states have internal predecessors, (69), 26 states have call successors, (26), 15 states have call predecessors, (26), 14 states have return successors, (23), 21 states have call predecessors, (23), 23 states have call successors, (23) [2022-04-08 13:24:21,167 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:24:21,167 INFO L93 Difference]: Finished difference Result 103 states and 118 transitions. [2022-04-08 13:24:21,167 INFO L276 IsEmpty]: Start isEmpty. Operand 103 states and 118 transitions. [2022-04-08 13:24:21,167 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:24:21,167 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:24:21,167 INFO L74 IsIncluded]: Start isIncluded. First operand has 103 states, 62 states have (on average 1.1129032258064515) internal successors, (69), 66 states have internal predecessors, (69), 26 states have call successors, (26), 15 states have call predecessors, (26), 14 states have return successors, (23), 21 states have call predecessors, (23), 23 states have call successors, (23) Second operand 103 states. [2022-04-08 13:24:21,168 INFO L87 Difference]: Start difference. First operand has 103 states, 62 states have (on average 1.1129032258064515) internal successors, (69), 66 states have internal predecessors, (69), 26 states have call successors, (26), 15 states have call predecessors, (26), 14 states have return successors, (23), 21 states have call predecessors, (23), 23 states have call successors, (23) Second operand 103 states. [2022-04-08 13:24:21,171 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:24:21,171 INFO L93 Difference]: Finished difference Result 103 states and 118 transitions. [2022-04-08 13:24:21,171 INFO L276 IsEmpty]: Start isEmpty. Operand 103 states and 118 transitions. [2022-04-08 13:24:21,171 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:24:21,171 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:24:21,171 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-08 13:24:21,171 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-08 13:24:21,172 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 103 states, 62 states have (on average 1.1129032258064515) internal successors, (69), 66 states have internal predecessors, (69), 26 states have call successors, (26), 15 states have call predecessors, (26), 14 states have return successors, (23), 21 states have call predecessors, (23), 23 states have call successors, (23) [2022-04-08 13:24:21,175 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 103 states to 103 states and 118 transitions. [2022-04-08 13:24:21,175 INFO L78 Accepts]: Start accepts. Automaton has 103 states and 118 transitions. Word has length 69 [2022-04-08 13:24:21,175 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-08 13:24:21,175 INFO L478 AbstractCegarLoop]: Abstraction has 103 states and 118 transitions. [2022-04-08 13:24:21,175 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 6 states, 6 states have (on average 3.5) internal successors, (21), 5 states have internal predecessors, (21), 3 states have call successors, (13), 2 states have call predecessors, (13), 1 states have return successors, (11), 3 states have call predecessors, (11), 3 states have call successors, (11) [2022-04-08 13:24:21,176 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 103 states and 118 transitions. [2022-04-08 13:24:21,286 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 118 edges. 118 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:24:21,286 INFO L276 IsEmpty]: Start isEmpty. Operand 103 states and 118 transitions. [2022-04-08 13:24:21,287 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 76 [2022-04-08 13:24:21,287 INFO L491 BasicCegarLoop]: Found error trace [2022-04-08 13:24:21,287 INFO L499 BasicCegarLoop]: trace histogram [11, 10, 10, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-08 13:24:21,305 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (6)] Forceful destruction successful, exit code 0 [2022-04-08 13:24:21,505 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable7,6 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:24:21,506 INFO L403 AbstractCegarLoop]: === Iteration 9 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-08 13:24:21,506 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-08 13:24:21,506 INFO L85 PathProgramCache]: Analyzing trace with hash -1554666020, now seen corresponding path program 1 times [2022-04-08 13:24:21,506 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-08 13:24:21,506 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [1209618494] [2022-04-08 13:24:25,597 INFO L97 AcceleratorQvasr]: Qvasr could not accelerate loop because java.lang.UnsupportedOperationException: Cannot deal with arrays. [2022-04-08 13:24:25,597 INFO L274 tedInterpolationCore]: Could not compute an accelerate. [2022-04-08 13:24:25,598 INFO L85 PathProgramCache]: Analyzing trace with hash -1554666020, now seen corresponding path program 2 times [2022-04-08 13:24:25,598 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-08 13:24:25,598 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [9452725] [2022-04-08 13:24:25,598 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-08 13:24:25,598 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-08 13:24:25,620 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-08 13:24:25,620 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [52847614] [2022-04-08 13:24:25,620 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-08 13:24:25,620 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:24:25,620 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-08 13:24:25,621 INFO L229 MonitoredProcess]: Starting monitored process 7 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-08 13:24:25,622 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (7)] Waiting until timeout for monitored process [2022-04-08 13:24:25,665 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-08 13:24:25,665 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-08 13:24:25,666 INFO L263 TraceCheckSpWp]: Trace formula consists of 183 conjuncts, 41 conjunts are in the unsatisfiable core [2022-04-08 13:24:25,677 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:24:25,678 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-08 13:24:26,241 INFO L272 TraceCheckUtils]: 0: Hoare triple {4547#true} call ULTIMATE.init(); {4547#true} is VALID [2022-04-08 13:24:26,241 INFO L290 TraceCheckUtils]: 1: Hoare triple {4547#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {4547#true} is VALID [2022-04-08 13:24:26,241 INFO L290 TraceCheckUtils]: 2: Hoare triple {4547#true} assume true; {4547#true} is VALID [2022-04-08 13:24:26,241 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {4547#true} {4547#true} #94#return; {4547#true} is VALID [2022-04-08 13:24:26,241 INFO L272 TraceCheckUtils]: 4: Hoare triple {4547#true} call #t~ret5 := main(); {4547#true} is VALID [2022-04-08 13:24:26,241 INFO L290 TraceCheckUtils]: 5: Hoare triple {4547#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {4547#true} is VALID [2022-04-08 13:24:26,241 INFO L272 TraceCheckUtils]: 6: Hoare triple {4547#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:26,241 INFO L290 TraceCheckUtils]: 7: Hoare triple {4547#true} ~cond := #in~cond; {4547#true} is VALID [2022-04-08 13:24:26,241 INFO L290 TraceCheckUtils]: 8: Hoare triple {4547#true} assume !(0 == ~cond); {4547#true} is VALID [2022-04-08 13:24:26,241 INFO L290 TraceCheckUtils]: 9: Hoare triple {4547#true} assume true; {4547#true} is VALID [2022-04-08 13:24:26,241 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {4547#true} {4547#true} #78#return; {4547#true} is VALID [2022-04-08 13:24:26,242 INFO L290 TraceCheckUtils]: 11: Hoare triple {4547#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {4585#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:24:26,242 INFO L290 TraceCheckUtils]: 12: Hoare triple {4585#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !false; {4585#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:24:26,242 INFO L272 TraceCheckUtils]: 13: Hoare triple {4585#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:26,242 INFO L290 TraceCheckUtils]: 14: Hoare triple {4547#true} ~cond := #in~cond; {4547#true} is VALID [2022-04-08 13:24:26,242 INFO L290 TraceCheckUtils]: 15: Hoare triple {4547#true} assume !(0 == ~cond); {4547#true} is VALID [2022-04-08 13:24:26,242 INFO L290 TraceCheckUtils]: 16: Hoare triple {4547#true} assume true; {4547#true} is VALID [2022-04-08 13:24:26,243 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {4547#true} {4585#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #80#return; {4585#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:24:26,243 INFO L272 TraceCheckUtils]: 18: Hoare triple {4585#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:26,243 INFO L290 TraceCheckUtils]: 19: Hoare triple {4547#true} ~cond := #in~cond; {4610#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:24:26,243 INFO L290 TraceCheckUtils]: 20: Hoare triple {4610#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {4614#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:24:26,244 INFO L290 TraceCheckUtils]: 21: Hoare triple {4614#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {4614#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:24:26,244 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {4614#(not (= |__VERIFIER_assert_#in~cond| 0))} {4585#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #82#return; {4585#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:24:26,244 INFO L272 TraceCheckUtils]: 23: Hoare triple {4585#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:26,244 INFO L290 TraceCheckUtils]: 24: Hoare triple {4547#true} ~cond := #in~cond; {4547#true} is VALID [2022-04-08 13:24:26,244 INFO L290 TraceCheckUtils]: 25: Hoare triple {4547#true} assume !(0 == ~cond); {4547#true} is VALID [2022-04-08 13:24:26,244 INFO L290 TraceCheckUtils]: 26: Hoare triple {4547#true} assume true; {4547#true} is VALID [2022-04-08 13:24:26,245 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {4547#true} {4585#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #84#return; {4585#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:24:26,245 INFO L290 TraceCheckUtils]: 28: Hoare triple {4585#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:24:26,246 INFO L290 TraceCheckUtils]: 29: Hoare triple {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} assume !false; {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:24:26,246 INFO L272 TraceCheckUtils]: 30: Hoare triple {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:26,246 INFO L290 TraceCheckUtils]: 31: Hoare triple {4547#true} ~cond := #in~cond; {4547#true} is VALID [2022-04-08 13:24:26,246 INFO L290 TraceCheckUtils]: 32: Hoare triple {4547#true} assume !(0 == ~cond); {4547#true} is VALID [2022-04-08 13:24:26,246 INFO L290 TraceCheckUtils]: 33: Hoare triple {4547#true} assume true; {4547#true} is VALID [2022-04-08 13:24:26,246 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {4547#true} {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #80#return; {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:24:26,246 INFO L272 TraceCheckUtils]: 35: Hoare triple {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:26,247 INFO L290 TraceCheckUtils]: 36: Hoare triple {4547#true} ~cond := #in~cond; {4547#true} is VALID [2022-04-08 13:24:26,247 INFO L290 TraceCheckUtils]: 37: Hoare triple {4547#true} assume !(0 == ~cond); {4547#true} is VALID [2022-04-08 13:24:26,247 INFO L290 TraceCheckUtils]: 38: Hoare triple {4547#true} assume true; {4547#true} is VALID [2022-04-08 13:24:26,247 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {4547#true} {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #82#return; {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:24:26,247 INFO L272 TraceCheckUtils]: 40: Hoare triple {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:26,247 INFO L290 TraceCheckUtils]: 41: Hoare triple {4547#true} ~cond := #in~cond; {4547#true} is VALID [2022-04-08 13:24:26,247 INFO L290 TraceCheckUtils]: 42: Hoare triple {4547#true} assume !(0 == ~cond); {4547#true} is VALID [2022-04-08 13:24:26,247 INFO L290 TraceCheckUtils]: 43: Hoare triple {4547#true} assume true; {4547#true} is VALID [2022-04-08 13:24:26,248 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {4547#true} {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #84#return; {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:24:26,248 INFO L290 TraceCheckUtils]: 45: Hoare triple {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} assume !(~r~0 >= ~d~0); {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:24:26,249 INFO L290 TraceCheckUtils]: 46: Hoare triple {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} assume !false; {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:24:26,249 INFO L272 TraceCheckUtils]: 47: Hoare triple {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:26,249 INFO L290 TraceCheckUtils]: 48: Hoare triple {4547#true} ~cond := #in~cond; {4547#true} is VALID [2022-04-08 13:24:26,249 INFO L290 TraceCheckUtils]: 49: Hoare triple {4547#true} assume !(0 == ~cond); {4547#true} is VALID [2022-04-08 13:24:26,249 INFO L290 TraceCheckUtils]: 50: Hoare triple {4547#true} assume true; {4547#true} is VALID [2022-04-08 13:24:26,249 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {4547#true} {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #86#return; {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:24:26,249 INFO L272 TraceCheckUtils]: 52: Hoare triple {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:26,249 INFO L290 TraceCheckUtils]: 53: Hoare triple {4547#true} ~cond := #in~cond; {4547#true} is VALID [2022-04-08 13:24:26,249 INFO L290 TraceCheckUtils]: 54: Hoare triple {4547#true} assume !(0 == ~cond); {4547#true} is VALID [2022-04-08 13:24:26,250 INFO L290 TraceCheckUtils]: 55: Hoare triple {4547#true} assume true; {4547#true} is VALID [2022-04-08 13:24:26,250 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {4547#true} {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #88#return; {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:24:26,251 INFO L290 TraceCheckUtils]: 57: Hoare triple {4639#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {4585#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:24:26,251 INFO L290 TraceCheckUtils]: 58: Hoare triple {4585#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {4730#(and (<= main_~p~0 main_~q~0) (= main_~B~0 1) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:24:26,251 INFO L290 TraceCheckUtils]: 59: Hoare triple {4730#(and (<= main_~p~0 main_~q~0) (= main_~B~0 1) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !false; {4730#(and (<= main_~p~0 main_~q~0) (= main_~B~0 1) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:24:26,252 INFO L272 TraceCheckUtils]: 60: Hoare triple {4730#(and (<= main_~p~0 main_~q~0) (= main_~B~0 1) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:26,252 INFO L290 TraceCheckUtils]: 61: Hoare triple {4547#true} ~cond := #in~cond; {4610#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:24:26,252 INFO L290 TraceCheckUtils]: 62: Hoare triple {4610#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {4614#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:24:26,252 INFO L290 TraceCheckUtils]: 63: Hoare triple {4614#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {4614#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:24:26,253 INFO L284 TraceCheckUtils]: 64: Hoare quadruple {4614#(not (= |__VERIFIER_assert_#in~cond| 0))} {4730#(and (<= main_~p~0 main_~q~0) (= main_~B~0 1) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #86#return; {4749#(and (= (+ main_~d~0 main_~r~0) main_~A~0) (= main_~B~0 1) (= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:24:26,253 INFO L272 TraceCheckUtils]: 65: Hoare triple {4749#(and (= (+ main_~d~0 main_~r~0) main_~A~0) (= main_~B~0 1) (= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:26,253 INFO L290 TraceCheckUtils]: 66: Hoare triple {4547#true} ~cond := #in~cond; {4610#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:24:26,254 INFO L290 TraceCheckUtils]: 67: Hoare triple {4610#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {4614#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:24:26,254 INFO L290 TraceCheckUtils]: 68: Hoare triple {4614#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {4614#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:24:26,254 INFO L284 TraceCheckUtils]: 69: Hoare quadruple {4614#(not (= |__VERIFIER_assert_#in~cond| 0))} {4749#(and (= (+ main_~d~0 main_~r~0) main_~A~0) (= main_~B~0 1) (= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #88#return; {4765#(and (= main_~A~0 (+ main_~q~0 main_~r~0)) (= main_~d~0 1) (= (+ main_~d~0 main_~r~0) main_~A~0) (= main_~p~0 1))} is VALID [2022-04-08 13:24:26,255 INFO L290 TraceCheckUtils]: 70: Hoare triple {4765#(and (= main_~A~0 (+ main_~q~0 main_~r~0)) (= main_~d~0 1) (= (+ main_~d~0 main_~r~0) main_~A~0) (= main_~p~0 1))} assume !(1 != ~p~0); {4769#(and (= main_~A~0 (+ main_~q~0 main_~r~0)) (= main_~d~0 1) (= (+ main_~d~0 main_~r~0) main_~A~0))} is VALID [2022-04-08 13:24:26,255 INFO L272 TraceCheckUtils]: 71: Hoare triple {4769#(and (= main_~A~0 (+ main_~q~0 main_~r~0)) (= main_~d~0 1) (= (+ main_~d~0 main_~r~0) main_~A~0))} call __VERIFIER_assert((if ~A~0 == ~d~0 * ~q~0 + ~r~0 then 1 else 0)); {4773#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:24:26,256 INFO L290 TraceCheckUtils]: 72: Hoare triple {4773#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {4777#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:24:26,256 INFO L290 TraceCheckUtils]: 73: Hoare triple {4777#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {4548#false} is VALID [2022-04-08 13:24:26,256 INFO L290 TraceCheckUtils]: 74: Hoare triple {4548#false} assume !false; {4548#false} is VALID [2022-04-08 13:24:26,256 INFO L134 CoverageAnalysis]: Checked inductivity of 209 backedges. 62 proven. 30 refuted. 0 times theorem prover too weak. 117 trivial. 0 not checked. [2022-04-08 13:24:26,256 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-08 13:24:36,909 INFO L290 TraceCheckUtils]: 74: Hoare triple {4548#false} assume !false; {4548#false} is VALID [2022-04-08 13:24:36,909 INFO L290 TraceCheckUtils]: 73: Hoare triple {4777#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {4548#false} is VALID [2022-04-08 13:24:36,909 INFO L290 TraceCheckUtils]: 72: Hoare triple {4773#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {4777#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:24:36,910 INFO L272 TraceCheckUtils]: 71: Hoare triple {4793#(= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0)} call __VERIFIER_assert((if ~A~0 == ~d~0 * ~q~0 + ~r~0 then 1 else 0)); {4773#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:24:36,910 INFO L290 TraceCheckUtils]: 70: Hoare triple {4797#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} assume !(1 != ~p~0); {4793#(= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:24:36,911 INFO L284 TraceCheckUtils]: 69: Hoare quadruple {4614#(not (= |__VERIFIER_assert_#in~cond| 0))} {4801#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= (* main_~B~0 main_~p~0) main_~d~0)) (not (= main_~p~0 1)))} #88#return; {4797#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} is VALID [2022-04-08 13:24:36,911 INFO L290 TraceCheckUtils]: 68: Hoare triple {4614#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {4614#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:24:36,911 INFO L290 TraceCheckUtils]: 67: Hoare triple {4811#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} assume !(0 == ~cond); {4614#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:24:36,912 INFO L290 TraceCheckUtils]: 66: Hoare triple {4547#true} ~cond := #in~cond; {4811#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} is VALID [2022-04-08 13:24:36,912 INFO L272 TraceCheckUtils]: 65: Hoare triple {4801#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= (* main_~B~0 main_~p~0) main_~d~0)) (not (= main_~p~0 1)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:36,914 INFO L284 TraceCheckUtils]: 64: Hoare quadruple {4614#(not (= |__VERIFIER_assert_#in~cond| 0))} {4547#true} #86#return; {4801#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= (* main_~B~0 main_~p~0) main_~d~0)) (not (= main_~p~0 1)))} is VALID [2022-04-08 13:24:36,914 INFO L290 TraceCheckUtils]: 63: Hoare triple {4614#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {4614#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:24:36,914 INFO L290 TraceCheckUtils]: 62: Hoare triple {4811#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} assume !(0 == ~cond); {4614#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:24:36,914 INFO L290 TraceCheckUtils]: 61: Hoare triple {4547#true} ~cond := #in~cond; {4811#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} is VALID [2022-04-08 13:24:36,914 INFO L272 TraceCheckUtils]: 60: Hoare triple {4547#true} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:36,915 INFO L290 TraceCheckUtils]: 59: Hoare triple {4547#true} assume !false; {4547#true} is VALID [2022-04-08 13:24:36,915 INFO L290 TraceCheckUtils]: 58: Hoare triple {4547#true} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {4547#true} is VALID [2022-04-08 13:24:36,915 INFO L290 TraceCheckUtils]: 57: Hoare triple {4547#true} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {4547#true} is VALID [2022-04-08 13:24:36,915 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {4547#true} {4547#true} #88#return; {4547#true} is VALID [2022-04-08 13:24:36,915 INFO L290 TraceCheckUtils]: 55: Hoare triple {4547#true} assume true; {4547#true} is VALID [2022-04-08 13:24:36,915 INFO L290 TraceCheckUtils]: 54: Hoare triple {4547#true} assume !(0 == ~cond); {4547#true} is VALID [2022-04-08 13:24:36,915 INFO L290 TraceCheckUtils]: 53: Hoare triple {4547#true} ~cond := #in~cond; {4547#true} is VALID [2022-04-08 13:24:36,915 INFO L272 TraceCheckUtils]: 52: Hoare triple {4547#true} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:36,915 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {4547#true} {4547#true} #86#return; {4547#true} is VALID [2022-04-08 13:24:36,915 INFO L290 TraceCheckUtils]: 50: Hoare triple {4547#true} assume true; {4547#true} is VALID [2022-04-08 13:24:36,915 INFO L290 TraceCheckUtils]: 49: Hoare triple {4547#true} assume !(0 == ~cond); {4547#true} is VALID [2022-04-08 13:24:36,915 INFO L290 TraceCheckUtils]: 48: Hoare triple {4547#true} ~cond := #in~cond; {4547#true} is VALID [2022-04-08 13:24:36,915 INFO L272 TraceCheckUtils]: 47: Hoare triple {4547#true} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:36,915 INFO L290 TraceCheckUtils]: 46: Hoare triple {4547#true} assume !false; {4547#true} is VALID [2022-04-08 13:24:36,915 INFO L290 TraceCheckUtils]: 45: Hoare triple {4547#true} assume !(~r~0 >= ~d~0); {4547#true} is VALID [2022-04-08 13:24:36,915 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {4547#true} {4547#true} #84#return; {4547#true} is VALID [2022-04-08 13:24:36,915 INFO L290 TraceCheckUtils]: 43: Hoare triple {4547#true} assume true; {4547#true} is VALID [2022-04-08 13:24:36,916 INFO L290 TraceCheckUtils]: 42: Hoare triple {4547#true} assume !(0 == ~cond); {4547#true} is VALID [2022-04-08 13:24:36,916 INFO L290 TraceCheckUtils]: 41: Hoare triple {4547#true} ~cond := #in~cond; {4547#true} is VALID [2022-04-08 13:24:36,916 INFO L272 TraceCheckUtils]: 40: Hoare triple {4547#true} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:36,916 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {4547#true} {4547#true} #82#return; {4547#true} is VALID [2022-04-08 13:24:36,916 INFO L290 TraceCheckUtils]: 38: Hoare triple {4547#true} assume true; {4547#true} is VALID [2022-04-08 13:24:36,916 INFO L290 TraceCheckUtils]: 37: Hoare triple {4547#true} assume !(0 == ~cond); {4547#true} is VALID [2022-04-08 13:24:36,916 INFO L290 TraceCheckUtils]: 36: Hoare triple {4547#true} ~cond := #in~cond; {4547#true} is VALID [2022-04-08 13:24:36,916 INFO L272 TraceCheckUtils]: 35: Hoare triple {4547#true} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:36,916 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {4547#true} {4547#true} #80#return; {4547#true} is VALID [2022-04-08 13:24:36,916 INFO L290 TraceCheckUtils]: 33: Hoare triple {4547#true} assume true; {4547#true} is VALID [2022-04-08 13:24:36,916 INFO L290 TraceCheckUtils]: 32: Hoare triple {4547#true} assume !(0 == ~cond); {4547#true} is VALID [2022-04-08 13:24:36,916 INFO L290 TraceCheckUtils]: 31: Hoare triple {4547#true} ~cond := #in~cond; {4547#true} is VALID [2022-04-08 13:24:36,916 INFO L272 TraceCheckUtils]: 30: Hoare triple {4547#true} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:36,916 INFO L290 TraceCheckUtils]: 29: Hoare triple {4547#true} assume !false; {4547#true} is VALID [2022-04-08 13:24:36,916 INFO L290 TraceCheckUtils]: 28: Hoare triple {4547#true} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {4547#true} is VALID [2022-04-08 13:24:36,916 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {4547#true} {4547#true} #84#return; {4547#true} is VALID [2022-04-08 13:24:36,916 INFO L290 TraceCheckUtils]: 26: Hoare triple {4547#true} assume true; {4547#true} is VALID [2022-04-08 13:24:36,917 INFO L290 TraceCheckUtils]: 25: Hoare triple {4547#true} assume !(0 == ~cond); {4547#true} is VALID [2022-04-08 13:24:36,917 INFO L290 TraceCheckUtils]: 24: Hoare triple {4547#true} ~cond := #in~cond; {4547#true} is VALID [2022-04-08 13:24:36,917 INFO L272 TraceCheckUtils]: 23: Hoare triple {4547#true} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:36,917 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {4547#true} {4547#true} #82#return; {4547#true} is VALID [2022-04-08 13:24:36,917 INFO L290 TraceCheckUtils]: 21: Hoare triple {4547#true} assume true; {4547#true} is VALID [2022-04-08 13:24:36,917 INFO L290 TraceCheckUtils]: 20: Hoare triple {4547#true} assume !(0 == ~cond); {4547#true} is VALID [2022-04-08 13:24:36,917 INFO L290 TraceCheckUtils]: 19: Hoare triple {4547#true} ~cond := #in~cond; {4547#true} is VALID [2022-04-08 13:24:36,917 INFO L272 TraceCheckUtils]: 18: Hoare triple {4547#true} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:36,917 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {4547#true} {4547#true} #80#return; {4547#true} is VALID [2022-04-08 13:24:36,917 INFO L290 TraceCheckUtils]: 16: Hoare triple {4547#true} assume true; {4547#true} is VALID [2022-04-08 13:24:36,917 INFO L290 TraceCheckUtils]: 15: Hoare triple {4547#true} assume !(0 == ~cond); {4547#true} is VALID [2022-04-08 13:24:36,917 INFO L290 TraceCheckUtils]: 14: Hoare triple {4547#true} ~cond := #in~cond; {4547#true} is VALID [2022-04-08 13:24:36,917 INFO L272 TraceCheckUtils]: 13: Hoare triple {4547#true} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:36,917 INFO L290 TraceCheckUtils]: 12: Hoare triple {4547#true} assume !false; {4547#true} is VALID [2022-04-08 13:24:36,917 INFO L290 TraceCheckUtils]: 11: Hoare triple {4547#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {4547#true} is VALID [2022-04-08 13:24:36,917 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {4547#true} {4547#true} #78#return; {4547#true} is VALID [2022-04-08 13:24:36,917 INFO L290 TraceCheckUtils]: 9: Hoare triple {4547#true} assume true; {4547#true} is VALID [2022-04-08 13:24:36,918 INFO L290 TraceCheckUtils]: 8: Hoare triple {4547#true} assume !(0 == ~cond); {4547#true} is VALID [2022-04-08 13:24:36,918 INFO L290 TraceCheckUtils]: 7: Hoare triple {4547#true} ~cond := #in~cond; {4547#true} is VALID [2022-04-08 13:24:36,918 INFO L272 TraceCheckUtils]: 6: Hoare triple {4547#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {4547#true} is VALID [2022-04-08 13:24:36,918 INFO L290 TraceCheckUtils]: 5: Hoare triple {4547#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {4547#true} is VALID [2022-04-08 13:24:36,918 INFO L272 TraceCheckUtils]: 4: Hoare triple {4547#true} call #t~ret5 := main(); {4547#true} is VALID [2022-04-08 13:24:36,918 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {4547#true} {4547#true} #94#return; {4547#true} is VALID [2022-04-08 13:24:36,918 INFO L290 TraceCheckUtils]: 2: Hoare triple {4547#true} assume true; {4547#true} is VALID [2022-04-08 13:24:36,918 INFO L290 TraceCheckUtils]: 1: Hoare triple {4547#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {4547#true} is VALID [2022-04-08 13:24:36,918 INFO L272 TraceCheckUtils]: 0: Hoare triple {4547#true} call ULTIMATE.init(); {4547#true} is VALID [2022-04-08 13:24:36,918 INFO L134 CoverageAnalysis]: Checked inductivity of 209 backedges. 68 proven. 2 refuted. 0 times theorem prover too weak. 139 trivial. 0 not checked. [2022-04-08 13:24:36,918 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-08 13:24:36,918 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [9452725] [2022-04-08 13:24:36,918 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-08 13:24:36,919 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [52847614] [2022-04-08 13:24:36,919 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [52847614] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-08 13:24:36,919 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-08 13:24:36,919 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [12, 9] total 16 [2022-04-08 13:24:36,919 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-08 13:24:36,919 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [1209618494] [2022-04-08 13:24:36,919 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [1209618494] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:24:36,919 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:24:36,919 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [12] imperfect sequences [] total 12 [2022-04-08 13:24:36,919 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [900745406] [2022-04-08 13:24:36,919 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-08 13:24:36,920 INFO L78 Accepts]: Start accepts. Automaton has has 12 states, 10 states have (on average 2.5) internal successors, (25), 9 states have internal predecessors, (25), 6 states have call successors, (14), 2 states have call predecessors, (14), 2 states have return successors, (12), 5 states have call predecessors, (12), 5 states have call successors, (12) Word has length 75 [2022-04-08 13:24:36,920 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-08 13:24:36,920 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 12 states, 10 states have (on average 2.5) internal successors, (25), 9 states have internal predecessors, (25), 6 states have call successors, (14), 2 states have call predecessors, (14), 2 states have return successors, (12), 5 states have call predecessors, (12), 5 states have call successors, (12) [2022-04-08 13:24:36,955 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 51 edges. 51 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:24:36,955 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 12 states [2022-04-08 13:24:36,955 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-08 13:24:36,956 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 12 interpolants. [2022-04-08 13:24:36,956 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=55, Invalid=185, Unknown=0, NotChecked=0, Total=240 [2022-04-08 13:24:36,956 INFO L87 Difference]: Start difference. First operand 103 states and 118 transitions. Second operand has 12 states, 10 states have (on average 2.5) internal successors, (25), 9 states have internal predecessors, (25), 6 states have call successors, (14), 2 states have call predecessors, (14), 2 states have return successors, (12), 5 states have call predecessors, (12), 5 states have call successors, (12) [2022-04-08 13:24:37,744 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:24:37,744 INFO L93 Difference]: Finished difference Result 109 states and 123 transitions. [2022-04-08 13:24:37,744 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 9 states. [2022-04-08 13:24:37,744 INFO L78 Accepts]: Start accepts. Automaton has has 12 states, 10 states have (on average 2.5) internal successors, (25), 9 states have internal predecessors, (25), 6 states have call successors, (14), 2 states have call predecessors, (14), 2 states have return successors, (12), 5 states have call predecessors, (12), 5 states have call successors, (12) Word has length 75 [2022-04-08 13:24:37,744 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-08 13:24:37,745 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 12 states, 10 states have (on average 2.5) internal successors, (25), 9 states have internal predecessors, (25), 6 states have call successors, (14), 2 states have call predecessors, (14), 2 states have return successors, (12), 5 states have call predecessors, (12), 5 states have call successors, (12) [2022-04-08 13:24:37,750 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 9 states to 9 states and 74 transitions. [2022-04-08 13:24:37,751 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 12 states, 10 states have (on average 2.5) internal successors, (25), 9 states have internal predecessors, (25), 6 states have call successors, (14), 2 states have call predecessors, (14), 2 states have return successors, (12), 5 states have call predecessors, (12), 5 states have call successors, (12) [2022-04-08 13:24:37,752 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 9 states to 9 states and 74 transitions. [2022-04-08 13:24:37,752 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 9 states and 74 transitions. [2022-04-08 13:24:37,811 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 74 edges. 74 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:24:37,812 INFO L225 Difference]: With dead ends: 109 [2022-04-08 13:24:37,812 INFO L226 Difference]: Without dead ends: 81 [2022-04-08 13:24:37,812 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 151 GetRequests, 133 SyntacticMatches, 2 SemanticMatches, 16 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 30 ImplicationChecksByTransitivity, 0.1s TimeCoverageRelationStatistics Valid=68, Invalid=238, Unknown=0, NotChecked=0, Total=306 [2022-04-08 13:24:37,813 INFO L913 BasicCegarLoop]: 31 mSDtfsCounter, 14 mSDsluCounter, 141 mSDsCounter, 0 mSdLazyCounter, 354 mSolverCounterSat, 24 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.3s Time, 0 mProtectedPredicate, 0 mProtectedAction, 15 SdHoareTripleChecker+Valid, 172 SdHoareTripleChecker+Invalid, 378 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 24 IncrementalHoareTripleChecker+Valid, 354 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.3s IncrementalHoareTripleChecker+Time [2022-04-08 13:24:37,813 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [15 Valid, 172 Invalid, 378 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [24 Valid, 354 Invalid, 0 Unknown, 0 Unchecked, 0.3s Time] [2022-04-08 13:24:37,813 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 81 states. [2022-04-08 13:24:37,846 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 81 to 81. [2022-04-08 13:24:37,846 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-08 13:24:37,847 INFO L82 GeneralOperation]: Start isEquivalent. First operand 81 states. Second operand has 81 states, 48 states have (on average 1.125) internal successors, (54), 51 states have internal predecessors, (54), 21 states have call successors, (21), 12 states have call predecessors, (21), 11 states have return successors, (19), 17 states have call predecessors, (19), 19 states have call successors, (19) [2022-04-08 13:24:37,848 INFO L74 IsIncluded]: Start isIncluded. First operand 81 states. Second operand has 81 states, 48 states have (on average 1.125) internal successors, (54), 51 states have internal predecessors, (54), 21 states have call successors, (21), 12 states have call predecessors, (21), 11 states have return successors, (19), 17 states have call predecessors, (19), 19 states have call successors, (19) [2022-04-08 13:24:37,848 INFO L87 Difference]: Start difference. First operand 81 states. Second operand has 81 states, 48 states have (on average 1.125) internal successors, (54), 51 states have internal predecessors, (54), 21 states have call successors, (21), 12 states have call predecessors, (21), 11 states have return successors, (19), 17 states have call predecessors, (19), 19 states have call successors, (19) [2022-04-08 13:24:37,852 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:24:37,852 INFO L93 Difference]: Finished difference Result 81 states and 94 transitions. [2022-04-08 13:24:37,852 INFO L276 IsEmpty]: Start isEmpty. Operand 81 states and 94 transitions. [2022-04-08 13:24:37,852 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:24:37,852 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:24:37,852 INFO L74 IsIncluded]: Start isIncluded. First operand has 81 states, 48 states have (on average 1.125) internal successors, (54), 51 states have internal predecessors, (54), 21 states have call successors, (21), 12 states have call predecessors, (21), 11 states have return successors, (19), 17 states have call predecessors, (19), 19 states have call successors, (19) Second operand 81 states. [2022-04-08 13:24:37,852 INFO L87 Difference]: Start difference. First operand has 81 states, 48 states have (on average 1.125) internal successors, (54), 51 states have internal predecessors, (54), 21 states have call successors, (21), 12 states have call predecessors, (21), 11 states have return successors, (19), 17 states have call predecessors, (19), 19 states have call successors, (19) Second operand 81 states. [2022-04-08 13:24:37,854 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:24:37,854 INFO L93 Difference]: Finished difference Result 81 states and 94 transitions. [2022-04-08 13:24:37,854 INFO L276 IsEmpty]: Start isEmpty. Operand 81 states and 94 transitions. [2022-04-08 13:24:37,854 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:24:37,854 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:24:37,854 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-08 13:24:37,855 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-08 13:24:37,855 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 81 states, 48 states have (on average 1.125) internal successors, (54), 51 states have internal predecessors, (54), 21 states have call successors, (21), 12 states have call predecessors, (21), 11 states have return successors, (19), 17 states have call predecessors, (19), 19 states have call successors, (19) [2022-04-08 13:24:37,856 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 81 states to 81 states and 94 transitions. [2022-04-08 13:24:37,856 INFO L78 Accepts]: Start accepts. Automaton has 81 states and 94 transitions. Word has length 75 [2022-04-08 13:24:37,856 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-08 13:24:37,856 INFO L478 AbstractCegarLoop]: Abstraction has 81 states and 94 transitions. [2022-04-08 13:24:37,856 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 12 states, 10 states have (on average 2.5) internal successors, (25), 9 states have internal predecessors, (25), 6 states have call successors, (14), 2 states have call predecessors, (14), 2 states have return successors, (12), 5 states have call predecessors, (12), 5 states have call successors, (12) [2022-04-08 13:24:37,856 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 81 states and 94 transitions. [2022-04-08 13:24:37,942 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 94 edges. 94 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:24:37,943 INFO L276 IsEmpty]: Start isEmpty. Operand 81 states and 94 transitions. [2022-04-08 13:24:37,943 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 82 [2022-04-08 13:24:37,943 INFO L491 BasicCegarLoop]: Found error trace [2022-04-08 13:24:37,943 INFO L499 BasicCegarLoop]: trace histogram [12, 11, 11, 3, 3, 3, 3, 3, 3, 3, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-08 13:24:37,959 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (7)] Forceful destruction successful, exit code 0 [2022-04-08 13:24:38,147 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable8,7 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:24:38,147 INFO L403 AbstractCegarLoop]: === Iteration 10 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-08 13:24:38,148 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-08 13:24:38,148 INFO L85 PathProgramCache]: Analyzing trace with hash 330473976, now seen corresponding path program 5 times [2022-04-08 13:24:38,148 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-08 13:24:38,148 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [2095460341] [2022-04-08 13:24:40,552 INFO L97 AcceleratorQvasr]: Qvasr could not accelerate loop because java.lang.UnsupportedOperationException: Cannot deal with arrays. [2022-04-08 13:24:40,552 INFO L274 tedInterpolationCore]: Could not compute an accelerate. [2022-04-08 13:24:40,552 INFO L85 PathProgramCache]: Analyzing trace with hash 330473976, now seen corresponding path program 6 times [2022-04-08 13:24:40,552 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-08 13:24:40,553 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [694687368] [2022-04-08 13:24:40,553 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-08 13:24:40,553 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-08 13:24:40,563 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-08 13:24:40,564 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1744624268] [2022-04-08 13:24:40,564 INFO L93 rtionOrderModulation]: Changing assertion order to MIX_INSIDE_OUTSIDE [2022-04-08 13:24:40,564 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:24:40,564 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-08 13:24:40,564 INFO L229 MonitoredProcess]: Starting monitored process 8 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-08 13:24:40,565 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (8)] Waiting until timeout for monitored process [2022-04-08 13:24:40,606 INFO L228 tOrderPrioritization]: Assert order MIX_INSIDE_OUTSIDE issued 4 check-sat command(s) [2022-04-08 13:24:40,607 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-08 13:24:40,607 INFO L263 TraceCheckSpWp]: Trace formula consists of 134 conjuncts, 28 conjunts are in the unsatisfiable core [2022-04-08 13:24:40,619 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:24:40,620 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-08 13:24:43,951 WARN L907 QuantifierPusher]: no eliminatee completely removed, nonetheless the elimination was considered successful [2022-04-08 13:24:46,014 WARN L907 QuantifierPusher]: no eliminatee completely removed, nonetheless the elimination was considered successful [2022-04-08 13:24:46,345 INFO L272 TraceCheckUtils]: 0: Hoare triple {5558#true} call ULTIMATE.init(); {5558#true} is VALID [2022-04-08 13:24:46,345 INFO L290 TraceCheckUtils]: 1: Hoare triple {5558#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {5558#true} is VALID [2022-04-08 13:24:46,345 INFO L290 TraceCheckUtils]: 2: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:24:46,345 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {5558#true} {5558#true} #94#return; {5558#true} is VALID [2022-04-08 13:24:46,345 INFO L272 TraceCheckUtils]: 4: Hoare triple {5558#true} call #t~ret5 := main(); {5558#true} is VALID [2022-04-08 13:24:46,345 INFO L290 TraceCheckUtils]: 5: Hoare triple {5558#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {5558#true} is VALID [2022-04-08 13:24:46,345 INFO L272 TraceCheckUtils]: 6: Hoare triple {5558#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:24:46,345 INFO L290 TraceCheckUtils]: 7: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:24:46,345 INFO L290 TraceCheckUtils]: 8: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:24:46,345 INFO L290 TraceCheckUtils]: 9: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:24:46,345 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {5558#true} {5558#true} #78#return; {5558#true} is VALID [2022-04-08 13:24:46,346 INFO L290 TraceCheckUtils]: 11: Hoare triple {5558#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:24:46,346 INFO L290 TraceCheckUtils]: 12: Hoare triple {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} assume !false; {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:24:46,346 INFO L272 TraceCheckUtils]: 13: Hoare triple {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:24:46,346 INFO L290 TraceCheckUtils]: 14: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:24:46,346 INFO L290 TraceCheckUtils]: 15: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:24:46,346 INFO L290 TraceCheckUtils]: 16: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:24:46,347 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {5558#true} {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} #80#return; {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:24:46,347 INFO L272 TraceCheckUtils]: 18: Hoare triple {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:24:46,347 INFO L290 TraceCheckUtils]: 19: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:24:46,348 INFO L290 TraceCheckUtils]: 20: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:24:46,348 INFO L290 TraceCheckUtils]: 21: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:24:46,348 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {5558#true} {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} #82#return; {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:24:46,348 INFO L272 TraceCheckUtils]: 23: Hoare triple {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:24:46,348 INFO L290 TraceCheckUtils]: 24: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:24:46,348 INFO L290 TraceCheckUtils]: 25: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:24:46,348 INFO L290 TraceCheckUtils]: 26: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:24:46,349 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {5558#true} {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} #84#return; {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:24:46,349 INFO L290 TraceCheckUtils]: 28: Hoare triple {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:24:46,350 INFO L290 TraceCheckUtils]: 29: Hoare triple {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} assume !false; {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:24:46,350 INFO L272 TraceCheckUtils]: 30: Hoare triple {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:24:46,350 INFO L290 TraceCheckUtils]: 31: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:24:46,350 INFO L290 TraceCheckUtils]: 32: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:24:46,350 INFO L290 TraceCheckUtils]: 33: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:24:46,351 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {5558#true} {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} #80#return; {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:24:46,351 INFO L272 TraceCheckUtils]: 35: Hoare triple {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:24:46,351 INFO L290 TraceCheckUtils]: 36: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:24:46,351 INFO L290 TraceCheckUtils]: 37: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:24:46,351 INFO L290 TraceCheckUtils]: 38: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:24:46,351 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {5558#true} {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} #82#return; {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:24:46,351 INFO L272 TraceCheckUtils]: 40: Hoare triple {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:24:46,352 INFO L290 TraceCheckUtils]: 41: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:24:46,352 INFO L290 TraceCheckUtils]: 42: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:24:46,352 INFO L290 TraceCheckUtils]: 43: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:24:46,352 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {5558#true} {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} #84#return; {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:24:46,353 INFO L290 TraceCheckUtils]: 45: Hoare triple {5596#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {5699#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:24:46,353 INFO L290 TraceCheckUtils]: 46: Hoare triple {5699#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} assume !false; {5699#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:24:46,353 INFO L272 TraceCheckUtils]: 47: Hoare triple {5699#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:24:46,353 INFO L290 TraceCheckUtils]: 48: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:24:46,353 INFO L290 TraceCheckUtils]: 49: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:24:46,353 INFO L290 TraceCheckUtils]: 50: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:24:46,354 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {5558#true} {5699#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} #80#return; {5699#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:24:46,354 INFO L272 TraceCheckUtils]: 52: Hoare triple {5699#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:24:46,354 INFO L290 TraceCheckUtils]: 53: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:24:46,354 INFO L290 TraceCheckUtils]: 54: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:24:46,354 INFO L290 TraceCheckUtils]: 55: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:24:46,355 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {5558#true} {5699#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} #82#return; {5699#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:24:46,355 INFO L272 TraceCheckUtils]: 57: Hoare triple {5699#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:24:46,355 INFO L290 TraceCheckUtils]: 58: Hoare triple {5558#true} ~cond := #in~cond; {5739#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:24:46,355 INFO L290 TraceCheckUtils]: 59: Hoare triple {5739#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {5743#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:24:46,355 INFO L290 TraceCheckUtils]: 60: Hoare triple {5743#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {5743#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:24:46,356 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {5743#(not (= |__VERIFIER_assert_#in~cond| 0))} {5699#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} #84#return; {5750#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:24:46,356 INFO L290 TraceCheckUtils]: 62: Hoare triple {5750#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} assume !(~r~0 >= ~d~0); {5750#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:24:46,357 INFO L290 TraceCheckUtils]: 63: Hoare triple {5750#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} assume !false; {5750#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:24:46,357 INFO L272 TraceCheckUtils]: 64: Hoare triple {5750#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:24:46,357 INFO L290 TraceCheckUtils]: 65: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:24:46,357 INFO L290 TraceCheckUtils]: 66: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:24:46,357 INFO L290 TraceCheckUtils]: 67: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:24:46,358 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {5558#true} {5750#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} #86#return; {5750#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:24:46,358 INFO L272 TraceCheckUtils]: 69: Hoare triple {5750#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:24:46,358 INFO L290 TraceCheckUtils]: 70: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:24:46,358 INFO L290 TraceCheckUtils]: 71: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:24:46,358 INFO L290 TraceCheckUtils]: 72: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:24:46,358 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {5558#true} {5750#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} #88#return; {5750#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:24:46,359 INFO L290 TraceCheckUtils]: 74: Hoare triple {5750#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {5790#(and (= main_~A~0 main_~r~0) (< (* (div (+ (* (- 1) main_~B~0 main_~p~0) main_~d~0) main_~B~0) 2) 2) (<= 0 (* (div (+ (* (- 1) main_~B~0 main_~p~0) main_~d~0) main_~B~0) 2)) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:24:46,360 INFO L290 TraceCheckUtils]: 75: Hoare triple {5790#(and (= main_~A~0 main_~r~0) (< (* (div (+ (* (- 1) main_~B~0 main_~p~0) main_~d~0) main_~B~0) 2) 2) (<= 0 (* (div (+ (* (- 1) main_~B~0 main_~p~0) main_~d~0) main_~B~0) 2)) (= main_~q~0 0) (= main_~B~0 1))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {5794#(and (<= 0 (* (div (+ (* (- 1) main_~B~0 main_~q~0) main_~A~0 (* (- 1) main_~r~0)) main_~B~0) 2)) (< (* (div (+ (* (- 1) main_~B~0 main_~q~0) main_~A~0 (* (- 1) main_~r~0)) main_~B~0) 2) 2) (= main_~B~0 1))} is VALID [2022-04-08 13:24:46,360 INFO L290 TraceCheckUtils]: 76: Hoare triple {5794#(and (<= 0 (* (div (+ (* (- 1) main_~B~0 main_~q~0) main_~A~0 (* (- 1) main_~r~0)) main_~B~0) 2)) (< (* (div (+ (* (- 1) main_~B~0 main_~q~0) main_~A~0 (* (- 1) main_~r~0)) main_~B~0) 2) 2) (= main_~B~0 1))} assume !false; {5794#(and (<= 0 (* (div (+ (* (- 1) main_~B~0 main_~q~0) main_~A~0 (* (- 1) main_~r~0)) main_~B~0) 2)) (< (* (div (+ (* (- 1) main_~B~0 main_~q~0) main_~A~0 (* (- 1) main_~r~0)) main_~B~0) 2) 2) (= main_~B~0 1))} is VALID [2022-04-08 13:24:46,361 INFO L272 TraceCheckUtils]: 77: Hoare triple {5794#(and (<= 0 (* (div (+ (* (- 1) main_~B~0 main_~q~0) main_~A~0 (* (- 1) main_~r~0)) main_~B~0) 2)) (< (* (div (+ (* (- 1) main_~B~0 main_~q~0) main_~A~0 (* (- 1) main_~r~0)) main_~B~0) 2) 2) (= main_~B~0 1))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {5801#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:24:46,362 INFO L290 TraceCheckUtils]: 78: Hoare triple {5801#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {5805#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:24:46,362 INFO L290 TraceCheckUtils]: 79: Hoare triple {5805#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {5559#false} is VALID [2022-04-08 13:24:46,363 INFO L290 TraceCheckUtils]: 80: Hoare triple {5559#false} assume !false; {5559#false} is VALID [2022-04-08 13:24:46,363 INFO L134 CoverageAnalysis]: Checked inductivity of 259 backedges. 55 proven. 9 refuted. 0 times theorem prover too weak. 195 trivial. 0 not checked. [2022-04-08 13:24:46,363 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-08 13:25:22,245 WARN L232 SmtUtils]: Spent 7.38s on a formula simplification that was a NOOP. DAG size: 50 (called from [L 360] de.uni_freiburg.informatik.ultimate.lib.modelcheckerutils.smt.predicates.PredicateUnifier.getOrConstructPredicate) [2022-04-08 13:26:18,589 INFO L290 TraceCheckUtils]: 80: Hoare triple {5559#false} assume !false; {5559#false} is VALID [2022-04-08 13:26:18,590 INFO L290 TraceCheckUtils]: 79: Hoare triple {5805#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {5559#false} is VALID [2022-04-08 13:26:18,590 INFO L290 TraceCheckUtils]: 78: Hoare triple {5801#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {5805#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:26:18,590 INFO L272 TraceCheckUtils]: 77: Hoare triple {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {5801#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:26:18,591 INFO L290 TraceCheckUtils]: 76: Hoare triple {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} assume !false; {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:26:18,603 INFO L290 TraceCheckUtils]: 75: Hoare triple {5828#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:26:18,626 INFO L290 TraceCheckUtils]: 74: Hoare triple {5832#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {5828#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} is VALID [2022-04-08 13:26:18,627 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {5558#true} {5832#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} #88#return; {5832#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:26:18,627 INFO L290 TraceCheckUtils]: 72: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:26:18,627 INFO L290 TraceCheckUtils]: 71: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:26:18,627 INFO L290 TraceCheckUtils]: 70: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:26:18,627 INFO L272 TraceCheckUtils]: 69: Hoare triple {5832#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:26:18,628 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {5558#true} {5832#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} #86#return; {5832#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:26:18,628 INFO L290 TraceCheckUtils]: 67: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:26:18,628 INFO L290 TraceCheckUtils]: 66: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:26:18,628 INFO L290 TraceCheckUtils]: 65: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:26:18,628 INFO L272 TraceCheckUtils]: 64: Hoare triple {5832#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:26:18,629 INFO L290 TraceCheckUtils]: 63: Hoare triple {5832#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} assume !false; {5832#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:26:18,630 INFO L290 TraceCheckUtils]: 62: Hoare triple {5832#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} assume !(~r~0 >= ~d~0); {5832#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:26:18,630 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {5743#(not (= |__VERIFIER_assert_#in~cond| 0))} {5872#(or (and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)))))))) (not (= (* main_~B~0 main_~p~0) main_~d~0)))} #84#return; {5832#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:26:18,631 INFO L290 TraceCheckUtils]: 60: Hoare triple {5743#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {5743#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:26:18,631 INFO L290 TraceCheckUtils]: 59: Hoare triple {5882#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} assume !(0 == ~cond); {5743#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:26:18,631 INFO L290 TraceCheckUtils]: 58: Hoare triple {5558#true} ~cond := #in~cond; {5882#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} is VALID [2022-04-08 13:26:18,631 INFO L272 TraceCheckUtils]: 57: Hoare triple {5872#(or (and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)))))))) (not (= (* main_~B~0 main_~p~0) main_~d~0)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:26:18,632 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {5558#true} {5872#(or (and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)))))))) (not (= (* main_~B~0 main_~p~0) main_~d~0)))} #82#return; {5872#(or (and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)))))))) (not (= (* main_~B~0 main_~p~0) main_~d~0)))} is VALID [2022-04-08 13:26:18,632 INFO L290 TraceCheckUtils]: 55: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:26:18,632 INFO L290 TraceCheckUtils]: 54: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:26:18,632 INFO L290 TraceCheckUtils]: 53: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:26:18,632 INFO L272 TraceCheckUtils]: 52: Hoare triple {5872#(or (and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)))))))) (not (= (* main_~B~0 main_~p~0) main_~d~0)))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:26:18,641 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {5558#true} {5872#(or (and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)))))))) (not (= (* main_~B~0 main_~p~0) main_~d~0)))} #80#return; {5872#(or (and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)))))))) (not (= (* main_~B~0 main_~p~0) main_~d~0)))} is VALID [2022-04-08 13:26:18,641 INFO L290 TraceCheckUtils]: 50: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:26:18,641 INFO L290 TraceCheckUtils]: 49: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:26:18,641 INFO L290 TraceCheckUtils]: 48: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:26:18,642 INFO L272 TraceCheckUtils]: 47: Hoare triple {5872#(or (and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)))))))) (not (= (* main_~B~0 main_~p~0) main_~d~0)))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:26:18,642 INFO L290 TraceCheckUtils]: 46: Hoare triple {5872#(or (and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)))))))) (not (= (* main_~B~0 main_~p~0) main_~d~0)))} assume !false; {5872#(or (and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)))))))) (not (= (* main_~B~0 main_~p~0) main_~d~0)))} is VALID [2022-04-08 13:26:18,646 INFO L290 TraceCheckUtils]: 45: Hoare triple {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {5872#(or (and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)))))))) (not (= (* main_~B~0 main_~p~0) main_~d~0)))} is VALID [2022-04-08 13:26:18,647 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {5558#true} {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} #84#return; {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:26:18,647 INFO L290 TraceCheckUtils]: 43: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:26:18,647 INFO L290 TraceCheckUtils]: 42: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:26:18,647 INFO L290 TraceCheckUtils]: 41: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:26:18,647 INFO L272 TraceCheckUtils]: 40: Hoare triple {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:26:18,647 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {5558#true} {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} #82#return; {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:26:18,647 INFO L290 TraceCheckUtils]: 38: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:26:18,647 INFO L290 TraceCheckUtils]: 37: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:26:18,648 INFO L290 TraceCheckUtils]: 36: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:26:18,648 INFO L272 TraceCheckUtils]: 35: Hoare triple {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:26:18,648 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {5558#true} {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} #80#return; {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:26:18,648 INFO L290 TraceCheckUtils]: 33: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:26:18,648 INFO L290 TraceCheckUtils]: 32: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:26:18,648 INFO L290 TraceCheckUtils]: 31: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:26:18,648 INFO L272 TraceCheckUtils]: 30: Hoare triple {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:26:18,649 INFO L290 TraceCheckUtils]: 29: Hoare triple {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} assume !false; {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:26:18,649 INFO L290 TraceCheckUtils]: 28: Hoare triple {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:26:18,649 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {5558#true} {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} #84#return; {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:26:18,649 INFO L290 TraceCheckUtils]: 26: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:26:18,649 INFO L290 TraceCheckUtils]: 25: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:26:18,650 INFO L290 TraceCheckUtils]: 24: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:26:18,650 INFO L272 TraceCheckUtils]: 23: Hoare triple {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:26:18,650 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {5558#true} {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} #82#return; {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:26:18,650 INFO L290 TraceCheckUtils]: 21: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:26:18,650 INFO L290 TraceCheckUtils]: 20: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:26:18,650 INFO L290 TraceCheckUtils]: 19: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:26:18,650 INFO L272 TraceCheckUtils]: 18: Hoare triple {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:26:18,651 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {5558#true} {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} #80#return; {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:26:18,651 INFO L290 TraceCheckUtils]: 16: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:26:18,651 INFO L290 TraceCheckUtils]: 15: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:26:18,651 INFO L290 TraceCheckUtils]: 14: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:26:18,651 INFO L272 TraceCheckUtils]: 13: Hoare triple {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:26:18,651 INFO L290 TraceCheckUtils]: 12: Hoare triple {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} assume !false; {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:26:18,651 INFO L290 TraceCheckUtils]: 11: Hoare triple {5558#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {5821#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:26:18,652 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {5558#true} {5558#true} #78#return; {5558#true} is VALID [2022-04-08 13:26:18,652 INFO L290 TraceCheckUtils]: 9: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:26:18,652 INFO L290 TraceCheckUtils]: 8: Hoare triple {5558#true} assume !(0 == ~cond); {5558#true} is VALID [2022-04-08 13:26:18,652 INFO L290 TraceCheckUtils]: 7: Hoare triple {5558#true} ~cond := #in~cond; {5558#true} is VALID [2022-04-08 13:26:18,652 INFO L272 TraceCheckUtils]: 6: Hoare triple {5558#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {5558#true} is VALID [2022-04-08 13:26:18,652 INFO L290 TraceCheckUtils]: 5: Hoare triple {5558#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {5558#true} is VALID [2022-04-08 13:26:18,652 INFO L272 TraceCheckUtils]: 4: Hoare triple {5558#true} call #t~ret5 := main(); {5558#true} is VALID [2022-04-08 13:26:18,652 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {5558#true} {5558#true} #94#return; {5558#true} is VALID [2022-04-08 13:26:18,652 INFO L290 TraceCheckUtils]: 2: Hoare triple {5558#true} assume true; {5558#true} is VALID [2022-04-08 13:26:18,652 INFO L290 TraceCheckUtils]: 1: Hoare triple {5558#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {5558#true} is VALID [2022-04-08 13:26:18,652 INFO L272 TraceCheckUtils]: 0: Hoare triple {5558#true} call ULTIMATE.init(); {5558#true} is VALID [2022-04-08 13:26:18,653 INFO L134 CoverageAnalysis]: Checked inductivity of 259 backedges. 45 proven. 19 refuted. 0 times theorem prover too weak. 195 trivial. 0 not checked. [2022-04-08 13:26:18,653 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-08 13:26:18,653 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [694687368] [2022-04-08 13:26:18,653 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-08 13:26:18,653 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1744624268] [2022-04-08 13:26:18,653 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1744624268] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-08 13:26:18,653 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-08 13:26:18,653 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [11, 10] total 16 [2022-04-08 13:26:18,653 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-08 13:26:18,653 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [2095460341] [2022-04-08 13:26:18,653 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [2095460341] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:26:18,653 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:26:18,653 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [11] imperfect sequences [] total 11 [2022-04-08 13:26:18,653 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [552710923] [2022-04-08 13:26:18,653 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-08 13:26:18,654 INFO L78 Accepts]: Start accepts. Automaton has has 11 states, 11 states have (on average 2.272727272727273) internal successors, (25), 10 states have internal predecessors, (25), 5 states have call successors, (12), 2 states have call predecessors, (12), 2 states have return successors, (10), 4 states have call predecessors, (10), 4 states have call successors, (10) Word has length 81 [2022-04-08 13:26:18,654 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-08 13:26:18,654 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 11 states, 11 states have (on average 2.272727272727273) internal successors, (25), 10 states have internal predecessors, (25), 5 states have call successors, (12), 2 states have call predecessors, (12), 2 states have return successors, (10), 4 states have call predecessors, (10), 4 states have call successors, (10) [2022-04-08 13:26:18,690 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 47 edges. 47 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:26:18,690 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 11 states [2022-04-08 13:26:18,690 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-08 13:26:18,691 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 11 interpolants. [2022-04-08 13:26:18,691 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=57, Invalid=181, Unknown=2, NotChecked=0, Total=240 [2022-04-08 13:26:18,691 INFO L87 Difference]: Start difference. First operand 81 states and 94 transitions. Second operand has 11 states, 11 states have (on average 2.272727272727273) internal successors, (25), 10 states have internal predecessors, (25), 5 states have call successors, (12), 2 states have call predecessors, (12), 2 states have return successors, (10), 4 states have call predecessors, (10), 4 states have call successors, (10) [2022-04-08 13:26:23,307 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:26:23,307 INFO L93 Difference]: Finished difference Result 106 states and 124 transitions. [2022-04-08 13:26:23,307 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 9 states. [2022-04-08 13:26:23,307 INFO L78 Accepts]: Start accepts. Automaton has has 11 states, 11 states have (on average 2.272727272727273) internal successors, (25), 10 states have internal predecessors, (25), 5 states have call successors, (12), 2 states have call predecessors, (12), 2 states have return successors, (10), 4 states have call predecessors, (10), 4 states have call successors, (10) Word has length 81 [2022-04-08 13:26:23,308 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-08 13:26:23,308 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 11 states, 11 states have (on average 2.272727272727273) internal successors, (25), 10 states have internal predecessors, (25), 5 states have call successors, (12), 2 states have call predecessors, (12), 2 states have return successors, (10), 4 states have call predecessors, (10), 4 states have call successors, (10) [2022-04-08 13:26:23,309 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 9 states to 9 states and 89 transitions. [2022-04-08 13:26:23,309 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 11 states, 11 states have (on average 2.272727272727273) internal successors, (25), 10 states have internal predecessors, (25), 5 states have call successors, (12), 2 states have call predecessors, (12), 2 states have return successors, (10), 4 states have call predecessors, (10), 4 states have call successors, (10) [2022-04-08 13:26:23,310 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 9 states to 9 states and 89 transitions. [2022-04-08 13:26:23,310 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 9 states and 89 transitions. [2022-04-08 13:26:23,386 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 89 edges. 89 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:26:23,388 INFO L225 Difference]: With dead ends: 106 [2022-04-08 13:26:23,388 INFO L226 Difference]: Without dead ends: 94 [2022-04-08 13:26:23,388 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 163 GetRequests, 146 SyntacticMatches, 1 SemanticMatches, 16 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 70 ImplicationChecksByTransitivity, 15.7s TimeCoverageRelationStatistics Valid=70, Invalid=232, Unknown=4, NotChecked=0, Total=306 [2022-04-08 13:26:23,389 INFO L913 BasicCegarLoop]: 30 mSDtfsCounter, 28 mSDsluCounter, 99 mSDsCounter, 0 mSdLazyCounter, 222 mSolverCounterSat, 28 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.2s Time, 0 mProtectedPredicate, 0 mProtectedAction, 39 SdHoareTripleChecker+Valid, 129 SdHoareTripleChecker+Invalid, 250 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 28 IncrementalHoareTripleChecker+Valid, 222 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.2s IncrementalHoareTripleChecker+Time [2022-04-08 13:26:23,389 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [39 Valid, 129 Invalid, 250 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [28 Valid, 222 Invalid, 0 Unknown, 0 Unchecked, 0.2s Time] [2022-04-08 13:26:23,389 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 94 states. [2022-04-08 13:26:23,438 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 94 to 91. [2022-04-08 13:26:23,438 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-08 13:26:23,439 INFO L82 GeneralOperation]: Start isEquivalent. First operand 94 states. Second operand has 91 states, 55 states have (on average 1.1454545454545455) internal successors, (63), 57 states have internal predecessors, (63), 23 states have call successors, (23), 13 states have call predecessors, (23), 12 states have return successors, (21), 20 states have call predecessors, (21), 21 states have call successors, (21) [2022-04-08 13:26:23,439 INFO L74 IsIncluded]: Start isIncluded. First operand 94 states. Second operand has 91 states, 55 states have (on average 1.1454545454545455) internal successors, (63), 57 states have internal predecessors, (63), 23 states have call successors, (23), 13 states have call predecessors, (23), 12 states have return successors, (21), 20 states have call predecessors, (21), 21 states have call successors, (21) [2022-04-08 13:26:23,439 INFO L87 Difference]: Start difference. First operand 94 states. Second operand has 91 states, 55 states have (on average 1.1454545454545455) internal successors, (63), 57 states have internal predecessors, (63), 23 states have call successors, (23), 13 states have call predecessors, (23), 12 states have return successors, (21), 20 states have call predecessors, (21), 21 states have call successors, (21) [2022-04-08 13:26:23,441 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:26:23,441 INFO L93 Difference]: Finished difference Result 94 states and 111 transitions. [2022-04-08 13:26:23,441 INFO L276 IsEmpty]: Start isEmpty. Operand 94 states and 111 transitions. [2022-04-08 13:26:23,441 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:26:23,441 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:26:23,441 INFO L74 IsIncluded]: Start isIncluded. First operand has 91 states, 55 states have (on average 1.1454545454545455) internal successors, (63), 57 states have internal predecessors, (63), 23 states have call successors, (23), 13 states have call predecessors, (23), 12 states have return successors, (21), 20 states have call predecessors, (21), 21 states have call successors, (21) Second operand 94 states. [2022-04-08 13:26:23,441 INFO L87 Difference]: Start difference. First operand has 91 states, 55 states have (on average 1.1454545454545455) internal successors, (63), 57 states have internal predecessors, (63), 23 states have call successors, (23), 13 states have call predecessors, (23), 12 states have return successors, (21), 20 states have call predecessors, (21), 21 states have call successors, (21) Second operand 94 states. [2022-04-08 13:26:23,443 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:26:23,443 INFO L93 Difference]: Finished difference Result 94 states and 111 transitions. [2022-04-08 13:26:23,443 INFO L276 IsEmpty]: Start isEmpty. Operand 94 states and 111 transitions. [2022-04-08 13:26:23,443 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:26:23,443 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:26:23,443 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-08 13:26:23,443 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-08 13:26:23,443 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 91 states, 55 states have (on average 1.1454545454545455) internal successors, (63), 57 states have internal predecessors, (63), 23 states have call successors, (23), 13 states have call predecessors, (23), 12 states have return successors, (21), 20 states have call predecessors, (21), 21 states have call successors, (21) [2022-04-08 13:26:23,445 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 91 states to 91 states and 107 transitions. [2022-04-08 13:26:23,445 INFO L78 Accepts]: Start accepts. Automaton has 91 states and 107 transitions. Word has length 81 [2022-04-08 13:26:23,445 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-08 13:26:23,445 INFO L478 AbstractCegarLoop]: Abstraction has 91 states and 107 transitions. [2022-04-08 13:26:23,445 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 11 states, 11 states have (on average 2.272727272727273) internal successors, (25), 10 states have internal predecessors, (25), 5 states have call successors, (12), 2 states have call predecessors, (12), 2 states have return successors, (10), 4 states have call predecessors, (10), 4 states have call successors, (10) [2022-04-08 13:26:23,445 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 91 states and 107 transitions. [2022-04-08 13:26:23,555 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 107 edges. 107 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:26:23,555 INFO L276 IsEmpty]: Start isEmpty. Operand 91 states and 107 transitions. [2022-04-08 13:26:23,556 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 87 [2022-04-08 13:26:23,556 INFO L491 BasicCegarLoop]: Found error trace [2022-04-08 13:26:23,556 INFO L499 BasicCegarLoop]: trace histogram [13, 12, 12, 3, 3, 3, 3, 3, 3, 3, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-08 13:26:23,572 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (8)] Forceful destruction successful, exit code 0 [2022-04-08 13:26:23,756 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable9,8 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:26:23,756 INFO L403 AbstractCegarLoop]: === Iteration 11 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-08 13:26:23,757 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-08 13:26:23,757 INFO L85 PathProgramCache]: Analyzing trace with hash -454578581, now seen corresponding path program 7 times [2022-04-08 13:26:23,757 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-08 13:26:23,757 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [169292383] [2022-04-08 13:26:27,835 INFO L97 AcceleratorQvasr]: Qvasr could not accelerate loop because java.lang.UnsupportedOperationException: Cannot deal with arrays. [2022-04-08 13:26:27,835 INFO L274 tedInterpolationCore]: Could not compute an accelerate. [2022-04-08 13:26:27,835 INFO L85 PathProgramCache]: Analyzing trace with hash -454578581, now seen corresponding path program 8 times [2022-04-08 13:26:27,835 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-08 13:26:27,835 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1361391826] [2022-04-08 13:26:27,835 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-08 13:26:27,835 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-08 13:26:27,844 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-08 13:26:27,844 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1541387578] [2022-04-08 13:26:27,845 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-08 13:26:27,845 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:26:27,845 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-08 13:26:27,845 INFO L229 MonitoredProcess]: Starting monitored process 9 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-08 13:26:27,846 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (9)] Waiting until timeout for monitored process [2022-04-08 13:26:27,889 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-08 13:26:27,889 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-08 13:26:27,890 INFO L263 TraceCheckSpWp]: Trace formula consists of 205 conjuncts, 21 conjunts are in the unsatisfiable core [2022-04-08 13:26:27,902 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:26:27,903 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-08 13:26:28,211 INFO L272 TraceCheckUtils]: 0: Hoare triple {6645#true} call ULTIMATE.init(); {6645#true} is VALID [2022-04-08 13:26:28,211 INFO L290 TraceCheckUtils]: 1: Hoare triple {6645#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {6645#true} is VALID [2022-04-08 13:26:28,211 INFO L290 TraceCheckUtils]: 2: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:28,211 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {6645#true} {6645#true} #94#return; {6645#true} is VALID [2022-04-08 13:26:28,211 INFO L272 TraceCheckUtils]: 4: Hoare triple {6645#true} call #t~ret5 := main(); {6645#true} is VALID [2022-04-08 13:26:28,211 INFO L290 TraceCheckUtils]: 5: Hoare triple {6645#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {6645#true} is VALID [2022-04-08 13:26:28,211 INFO L272 TraceCheckUtils]: 6: Hoare triple {6645#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:28,211 INFO L290 TraceCheckUtils]: 7: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:28,211 INFO L290 TraceCheckUtils]: 8: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:28,211 INFO L290 TraceCheckUtils]: 9: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:28,211 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {6645#true} {6645#true} #78#return; {6645#true} is VALID [2022-04-08 13:26:28,227 INFO L290 TraceCheckUtils]: 11: Hoare triple {6645#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {6683#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:26:28,228 INFO L290 TraceCheckUtils]: 12: Hoare triple {6683#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !false; {6683#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:26:28,228 INFO L272 TraceCheckUtils]: 13: Hoare triple {6683#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:28,228 INFO L290 TraceCheckUtils]: 14: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:28,228 INFO L290 TraceCheckUtils]: 15: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:28,228 INFO L290 TraceCheckUtils]: 16: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:28,229 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {6645#true} {6683#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #80#return; {6683#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:26:28,229 INFO L272 TraceCheckUtils]: 18: Hoare triple {6683#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:28,229 INFO L290 TraceCheckUtils]: 19: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:28,229 INFO L290 TraceCheckUtils]: 20: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:28,229 INFO L290 TraceCheckUtils]: 21: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:28,229 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {6645#true} {6683#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #82#return; {6683#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:26:28,229 INFO L272 TraceCheckUtils]: 23: Hoare triple {6683#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:28,229 INFO L290 TraceCheckUtils]: 24: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:28,229 INFO L290 TraceCheckUtils]: 25: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:28,230 INFO L290 TraceCheckUtils]: 26: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:28,230 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {6645#true} {6683#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #84#return; {6683#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:26:28,230 INFO L290 TraceCheckUtils]: 28: Hoare triple {6683#(and (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:26:28,231 INFO L290 TraceCheckUtils]: 29: Hoare triple {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} assume !false; {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:26:28,231 INFO L272 TraceCheckUtils]: 30: Hoare triple {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:28,231 INFO L290 TraceCheckUtils]: 31: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:28,231 INFO L290 TraceCheckUtils]: 32: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:28,231 INFO L290 TraceCheckUtils]: 33: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:28,231 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {6645#true} {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} #80#return; {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:26:28,231 INFO L272 TraceCheckUtils]: 35: Hoare triple {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:28,232 INFO L290 TraceCheckUtils]: 36: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:28,232 INFO L290 TraceCheckUtils]: 37: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:28,232 INFO L290 TraceCheckUtils]: 38: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:28,232 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {6645#true} {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} #82#return; {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:26:28,232 INFO L272 TraceCheckUtils]: 40: Hoare triple {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:28,232 INFO L290 TraceCheckUtils]: 41: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:28,232 INFO L290 TraceCheckUtils]: 42: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:28,232 INFO L290 TraceCheckUtils]: 43: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:28,233 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {6645#true} {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} #84#return; {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:26:28,233 INFO L290 TraceCheckUtils]: 45: Hoare triple {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:26:28,233 INFO L290 TraceCheckUtils]: 46: Hoare triple {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} assume !false; {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:26:28,234 INFO L272 TraceCheckUtils]: 47: Hoare triple {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:28,234 INFO L290 TraceCheckUtils]: 48: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:28,234 INFO L290 TraceCheckUtils]: 49: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:28,234 INFO L290 TraceCheckUtils]: 50: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:28,234 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {6645#true} {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} #80#return; {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:26:28,234 INFO L272 TraceCheckUtils]: 52: Hoare triple {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:28,234 INFO L290 TraceCheckUtils]: 53: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:28,234 INFO L290 TraceCheckUtils]: 54: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:28,234 INFO L290 TraceCheckUtils]: 55: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:28,235 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {6645#true} {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} #82#return; {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:26:28,235 INFO L272 TraceCheckUtils]: 57: Hoare triple {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:28,235 INFO L290 TraceCheckUtils]: 58: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:28,235 INFO L290 TraceCheckUtils]: 59: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:28,235 INFO L290 TraceCheckUtils]: 60: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:28,235 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {6645#true} {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} #84#return; {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:26:28,236 INFO L290 TraceCheckUtils]: 62: Hoare triple {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} assume !(~r~0 >= ~d~0); {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:26:28,237 INFO L290 TraceCheckUtils]: 63: Hoare triple {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} assume !false; {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:26:28,237 INFO L272 TraceCheckUtils]: 64: Hoare triple {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:28,237 INFO L290 TraceCheckUtils]: 65: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:28,237 INFO L290 TraceCheckUtils]: 66: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:28,237 INFO L290 TraceCheckUtils]: 67: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:28,237 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {6645#true} {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} #86#return; {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:26:28,237 INFO L272 TraceCheckUtils]: 69: Hoare triple {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:28,237 INFO L290 TraceCheckUtils]: 70: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:28,238 INFO L290 TraceCheckUtils]: 71: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:28,238 INFO L290 TraceCheckUtils]: 72: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:28,238 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {6645#true} {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} #88#return; {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:26:28,238 INFO L290 TraceCheckUtils]: 74: Hoare triple {6787#(and (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:26:28,239 INFO L290 TraceCheckUtils]: 75: Hoare triple {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:26:28,239 INFO L290 TraceCheckUtils]: 76: Hoare triple {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} assume !false; {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:26:28,239 INFO L272 TraceCheckUtils]: 77: Hoare triple {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:28,239 INFO L290 TraceCheckUtils]: 78: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:28,239 INFO L290 TraceCheckUtils]: 79: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:28,239 INFO L290 TraceCheckUtils]: 80: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:28,240 INFO L284 TraceCheckUtils]: 81: Hoare quadruple {6645#true} {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} #86#return; {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} is VALID [2022-04-08 13:26:28,240 INFO L272 TraceCheckUtils]: 82: Hoare triple {6735#(and (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {6899#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:26:28,241 INFO L290 TraceCheckUtils]: 83: Hoare triple {6899#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {6903#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:26:28,241 INFO L290 TraceCheckUtils]: 84: Hoare triple {6903#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {6646#false} is VALID [2022-04-08 13:26:28,241 INFO L290 TraceCheckUtils]: 85: Hoare triple {6646#false} assume !false; {6646#false} is VALID [2022-04-08 13:26:28,241 INFO L134 CoverageAnalysis]: Checked inductivity of 306 backedges. 24 proven. 18 refuted. 0 times theorem prover too weak. 264 trivial. 0 not checked. [2022-04-08 13:26:28,241 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-08 13:26:36,114 INFO L290 TraceCheckUtils]: 85: Hoare triple {6646#false} assume !false; {6646#false} is VALID [2022-04-08 13:26:36,114 INFO L290 TraceCheckUtils]: 84: Hoare triple {6903#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {6646#false} is VALID [2022-04-08 13:26:36,114 INFO L290 TraceCheckUtils]: 83: Hoare triple {6899#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {6903#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:26:36,115 INFO L272 TraceCheckUtils]: 82: Hoare triple {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {6899#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:26:36,115 INFO L284 TraceCheckUtils]: 81: Hoare quadruple {6645#true} {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} #86#return; {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:26:36,115 INFO L290 TraceCheckUtils]: 80: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:36,115 INFO L290 TraceCheckUtils]: 79: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:36,116 INFO L290 TraceCheckUtils]: 78: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:36,116 INFO L272 TraceCheckUtils]: 77: Hoare triple {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:36,116 INFO L290 TraceCheckUtils]: 76: Hoare triple {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} assume !false; {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:26:36,117 INFO L290 TraceCheckUtils]: 75: Hoare triple {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:26:36,134 INFO L290 TraceCheckUtils]: 74: Hoare triple {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:26:36,135 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {6645#true} {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} #88#return; {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:26:36,135 INFO L290 TraceCheckUtils]: 72: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:36,135 INFO L290 TraceCheckUtils]: 71: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:36,135 INFO L290 TraceCheckUtils]: 70: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:36,135 INFO L272 TraceCheckUtils]: 69: Hoare triple {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:36,135 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {6645#true} {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} #86#return; {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:26:36,135 INFO L290 TraceCheckUtils]: 67: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:36,136 INFO L290 TraceCheckUtils]: 66: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:36,136 INFO L290 TraceCheckUtils]: 65: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:36,136 INFO L272 TraceCheckUtils]: 64: Hoare triple {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:36,136 INFO L290 TraceCheckUtils]: 63: Hoare triple {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} assume !false; {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:26:36,137 INFO L290 TraceCheckUtils]: 62: Hoare triple {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} assume !(~r~0 >= ~d~0); {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:26:36,138 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {6645#true} {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} #84#return; {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:26:36,138 INFO L290 TraceCheckUtils]: 60: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:36,138 INFO L290 TraceCheckUtils]: 59: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:36,138 INFO L290 TraceCheckUtils]: 58: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:36,138 INFO L272 TraceCheckUtils]: 57: Hoare triple {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:36,138 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {6645#true} {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} #82#return; {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:26:36,138 INFO L290 TraceCheckUtils]: 55: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:36,139 INFO L290 TraceCheckUtils]: 54: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:36,139 INFO L290 TraceCheckUtils]: 53: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:36,139 INFO L272 TraceCheckUtils]: 52: Hoare triple {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:36,139 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {6645#true} {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} #80#return; {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:26:36,139 INFO L290 TraceCheckUtils]: 50: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:36,139 INFO L290 TraceCheckUtils]: 49: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:36,139 INFO L290 TraceCheckUtils]: 48: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:36,139 INFO L272 TraceCheckUtils]: 47: Hoare triple {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:36,140 INFO L290 TraceCheckUtils]: 46: Hoare triple {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} assume !false; {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:26:36,145 INFO L290 TraceCheckUtils]: 45: Hoare triple {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {6944#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:26:36,145 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {6645#true} {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} #84#return; {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:26:36,145 INFO L290 TraceCheckUtils]: 43: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:36,145 INFO L290 TraceCheckUtils]: 42: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:36,145 INFO L290 TraceCheckUtils]: 41: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:36,145 INFO L272 TraceCheckUtils]: 40: Hoare triple {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:36,146 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {6645#true} {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} #82#return; {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:26:36,146 INFO L290 TraceCheckUtils]: 38: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:36,146 INFO L290 TraceCheckUtils]: 37: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:36,146 INFO L290 TraceCheckUtils]: 36: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:36,146 INFO L272 TraceCheckUtils]: 35: Hoare triple {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:36,146 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {6645#true} {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} #80#return; {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:26:36,147 INFO L290 TraceCheckUtils]: 33: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:36,147 INFO L290 TraceCheckUtils]: 32: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:36,147 INFO L290 TraceCheckUtils]: 31: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:36,147 INFO L272 TraceCheckUtils]: 30: Hoare triple {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:36,147 INFO L290 TraceCheckUtils]: 29: Hoare triple {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} assume !false; {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:26:36,149 INFO L290 TraceCheckUtils]: 28: Hoare triple {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:26:36,149 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {6645#true} {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} #84#return; {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:26:36,149 INFO L290 TraceCheckUtils]: 26: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:36,150 INFO L290 TraceCheckUtils]: 25: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:36,150 INFO L290 TraceCheckUtils]: 24: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:36,150 INFO L272 TraceCheckUtils]: 23: Hoare triple {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:36,150 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {6645#true} {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} #82#return; {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:26:36,150 INFO L290 TraceCheckUtils]: 21: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:36,150 INFO L290 TraceCheckUtils]: 20: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:36,150 INFO L290 TraceCheckUtils]: 19: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:36,150 INFO L272 TraceCheckUtils]: 18: Hoare triple {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:36,151 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {6645#true} {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} #80#return; {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:26:36,151 INFO L290 TraceCheckUtils]: 16: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:36,151 INFO L290 TraceCheckUtils]: 15: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:36,151 INFO L290 TraceCheckUtils]: 14: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:36,151 INFO L272 TraceCheckUtils]: 13: Hoare triple {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:36,151 INFO L290 TraceCheckUtils]: 12: Hoare triple {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} assume !false; {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:26:36,152 INFO L290 TraceCheckUtils]: 11: Hoare triple {6645#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {6919#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:26:36,152 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {6645#true} {6645#true} #78#return; {6645#true} is VALID [2022-04-08 13:26:36,152 INFO L290 TraceCheckUtils]: 9: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:36,152 INFO L290 TraceCheckUtils]: 8: Hoare triple {6645#true} assume !(0 == ~cond); {6645#true} is VALID [2022-04-08 13:26:36,152 INFO L290 TraceCheckUtils]: 7: Hoare triple {6645#true} ~cond := #in~cond; {6645#true} is VALID [2022-04-08 13:26:36,152 INFO L272 TraceCheckUtils]: 6: Hoare triple {6645#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {6645#true} is VALID [2022-04-08 13:26:36,152 INFO L290 TraceCheckUtils]: 5: Hoare triple {6645#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {6645#true} is VALID [2022-04-08 13:26:36,152 INFO L272 TraceCheckUtils]: 4: Hoare triple {6645#true} call #t~ret5 := main(); {6645#true} is VALID [2022-04-08 13:26:36,152 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {6645#true} {6645#true} #94#return; {6645#true} is VALID [2022-04-08 13:26:36,152 INFO L290 TraceCheckUtils]: 2: Hoare triple {6645#true} assume true; {6645#true} is VALID [2022-04-08 13:26:36,152 INFO L290 TraceCheckUtils]: 1: Hoare triple {6645#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {6645#true} is VALID [2022-04-08 13:26:36,152 INFO L272 TraceCheckUtils]: 0: Hoare triple {6645#true} call ULTIMATE.init(); {6645#true} is VALID [2022-04-08 13:26:36,153 INFO L134 CoverageAnalysis]: Checked inductivity of 306 backedges. 24 proven. 13 refuted. 0 times theorem prover too weak. 269 trivial. 0 not checked. [2022-04-08 13:26:36,153 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-08 13:26:36,153 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1361391826] [2022-04-08 13:26:36,153 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-08 13:26:36,153 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1541387578] [2022-04-08 13:26:36,153 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1541387578] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-08 13:26:36,153 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-08 13:26:36,153 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [7, 6] total 9 [2022-04-08 13:26:36,153 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-08 13:26:36,153 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [169292383] [2022-04-08 13:26:36,153 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [169292383] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:26:36,153 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:26:36,153 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [7] imperfect sequences [] total 7 [2022-04-08 13:26:36,154 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1242867203] [2022-04-08 13:26:36,154 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-08 13:26:36,154 INFO L78 Accepts]: Start accepts. Automaton has has 7 states, 7 states have (on average 3.2857142857142856) internal successors, (23), 6 states have internal predecessors, (23), 4 states have call successors, (16), 2 states have call predecessors, (16), 1 states have return successors, (14), 4 states have call predecessors, (14), 4 states have call successors, (14) Word has length 86 [2022-04-08 13:26:36,154 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-08 13:26:36,154 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 7 states, 7 states have (on average 3.2857142857142856) internal successors, (23), 6 states have internal predecessors, (23), 4 states have call successors, (16), 2 states have call predecessors, (16), 1 states have return successors, (14), 4 states have call predecessors, (14), 4 states have call successors, (14) [2022-04-08 13:26:36,194 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 53 edges. 53 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:26:36,194 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 7 states [2022-04-08 13:26:36,194 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-08 13:26:36,194 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 7 interpolants. [2022-04-08 13:26:36,194 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=21, Invalid=51, Unknown=0, NotChecked=0, Total=72 [2022-04-08 13:26:36,195 INFO L87 Difference]: Start difference. First operand 91 states and 107 transitions. Second operand has 7 states, 7 states have (on average 3.2857142857142856) internal successors, (23), 6 states have internal predecessors, (23), 4 states have call successors, (16), 2 states have call predecessors, (16), 1 states have return successors, (14), 4 states have call predecessors, (14), 4 states have call successors, (14) [2022-04-08 13:26:36,685 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:26:36,685 INFO L93 Difference]: Finished difference Result 170 states and 221 transitions. [2022-04-08 13:26:36,685 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 7 states. [2022-04-08 13:26:36,685 INFO L78 Accepts]: Start accepts. Automaton has has 7 states, 7 states have (on average 3.2857142857142856) internal successors, (23), 6 states have internal predecessors, (23), 4 states have call successors, (16), 2 states have call predecessors, (16), 1 states have return successors, (14), 4 states have call predecessors, (14), 4 states have call successors, (14) Word has length 86 [2022-04-08 13:26:36,685 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-08 13:26:36,685 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 7 states, 7 states have (on average 3.2857142857142856) internal successors, (23), 6 states have internal predecessors, (23), 4 states have call successors, (16), 2 states have call predecessors, (16), 1 states have return successors, (14), 4 states have call predecessors, (14), 4 states have call successors, (14) [2022-04-08 13:26:36,686 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 7 states to 7 states and 111 transitions. [2022-04-08 13:26:36,686 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 7 states, 7 states have (on average 3.2857142857142856) internal successors, (23), 6 states have internal predecessors, (23), 4 states have call successors, (16), 2 states have call predecessors, (16), 1 states have return successors, (14), 4 states have call predecessors, (14), 4 states have call successors, (14) [2022-04-08 13:26:36,688 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 7 states to 7 states and 111 transitions. [2022-04-08 13:26:36,688 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 7 states and 111 transitions. [2022-04-08 13:26:36,764 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 111 edges. 111 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:26:36,766 INFO L225 Difference]: With dead ends: 170 [2022-04-08 13:26:36,766 INFO L226 Difference]: Without dead ends: 132 [2022-04-08 13:26:36,767 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 172 GetRequests, 161 SyntacticMatches, 3 SemanticMatches, 8 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.1s TimeCoverageRelationStatistics Valid=25, Invalid=65, Unknown=0, NotChecked=0, Total=90 [2022-04-08 13:26:36,768 INFO L913 BasicCegarLoop]: 57 mSDtfsCounter, 10 mSDsluCounter, 176 mSDsCounter, 0 mSdLazyCounter, 182 mSolverCounterSat, 9 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.1s Time, 0 mProtectedPredicate, 0 mProtectedAction, 14 SdHoareTripleChecker+Valid, 233 SdHoareTripleChecker+Invalid, 191 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 9 IncrementalHoareTripleChecker+Valid, 182 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.1s IncrementalHoareTripleChecker+Time [2022-04-08 13:26:36,768 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [14 Valid, 233 Invalid, 191 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [9 Valid, 182 Invalid, 0 Unknown, 0 Unchecked, 0.1s Time] [2022-04-08 13:26:36,769 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 132 states. [2022-04-08 13:26:36,844 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 132 to 130. [2022-04-08 13:26:36,844 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-08 13:26:36,845 INFO L82 GeneralOperation]: Start isEquivalent. First operand 132 states. Second operand has 130 states, 78 states have (on average 1.141025641025641) internal successors, (89), 82 states have internal predecessors, (89), 36 states have call successors, (36), 16 states have call predecessors, (36), 15 states have return successors, (33), 31 states have call predecessors, (33), 33 states have call successors, (33) [2022-04-08 13:26:36,845 INFO L74 IsIncluded]: Start isIncluded. First operand 132 states. Second operand has 130 states, 78 states have (on average 1.141025641025641) internal successors, (89), 82 states have internal predecessors, (89), 36 states have call successors, (36), 16 states have call predecessors, (36), 15 states have return successors, (33), 31 states have call predecessors, (33), 33 states have call successors, (33) [2022-04-08 13:26:36,845 INFO L87 Difference]: Start difference. First operand 132 states. Second operand has 130 states, 78 states have (on average 1.141025641025641) internal successors, (89), 82 states have internal predecessors, (89), 36 states have call successors, (36), 16 states have call predecessors, (36), 15 states have return successors, (33), 31 states have call predecessors, (33), 33 states have call successors, (33) [2022-04-08 13:26:36,847 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:26:36,847 INFO L93 Difference]: Finished difference Result 132 states and 161 transitions. [2022-04-08 13:26:36,847 INFO L276 IsEmpty]: Start isEmpty. Operand 132 states and 161 transitions. [2022-04-08 13:26:36,848 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:26:36,848 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:26:36,848 INFO L74 IsIncluded]: Start isIncluded. First operand has 130 states, 78 states have (on average 1.141025641025641) internal successors, (89), 82 states have internal predecessors, (89), 36 states have call successors, (36), 16 states have call predecessors, (36), 15 states have return successors, (33), 31 states have call predecessors, (33), 33 states have call successors, (33) Second operand 132 states. [2022-04-08 13:26:36,848 INFO L87 Difference]: Start difference. First operand has 130 states, 78 states have (on average 1.141025641025641) internal successors, (89), 82 states have internal predecessors, (89), 36 states have call successors, (36), 16 states have call predecessors, (36), 15 states have return successors, (33), 31 states have call predecessors, (33), 33 states have call successors, (33) Second operand 132 states. [2022-04-08 13:26:36,850 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:26:36,850 INFO L93 Difference]: Finished difference Result 132 states and 161 transitions. [2022-04-08 13:26:36,850 INFO L276 IsEmpty]: Start isEmpty. Operand 132 states and 161 transitions. [2022-04-08 13:26:36,851 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:26:36,851 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:26:36,851 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-08 13:26:36,851 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-08 13:26:36,851 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 130 states, 78 states have (on average 1.141025641025641) internal successors, (89), 82 states have internal predecessors, (89), 36 states have call successors, (36), 16 states have call predecessors, (36), 15 states have return successors, (33), 31 states have call predecessors, (33), 33 states have call successors, (33) [2022-04-08 13:26:36,853 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 130 states to 130 states and 158 transitions. [2022-04-08 13:26:36,853 INFO L78 Accepts]: Start accepts. Automaton has 130 states and 158 transitions. Word has length 86 [2022-04-08 13:26:36,853 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-08 13:26:36,853 INFO L478 AbstractCegarLoop]: Abstraction has 130 states and 158 transitions. [2022-04-08 13:26:36,854 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 7 states, 7 states have (on average 3.2857142857142856) internal successors, (23), 6 states have internal predecessors, (23), 4 states have call successors, (16), 2 states have call predecessors, (16), 1 states have return successors, (14), 4 states have call predecessors, (14), 4 states have call successors, (14) [2022-04-08 13:26:36,854 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 130 states and 158 transitions. [2022-04-08 13:26:37,026 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 158 edges. 158 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:26:37,026 INFO L276 IsEmpty]: Start isEmpty. Operand 130 states and 158 transitions. [2022-04-08 13:26:37,027 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 95 [2022-04-08 13:26:37,027 INFO L491 BasicCegarLoop]: Found error trace [2022-04-08 13:26:37,027 INFO L499 BasicCegarLoop]: trace histogram [14, 13, 13, 3, 3, 3, 3, 3, 3, 3, 3, 3, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-08 13:26:37,047 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (9)] Forceful destruction successful, exit code 0 [2022-04-08 13:26:37,239 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 9 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable10 [2022-04-08 13:26:37,239 INFO L403 AbstractCegarLoop]: === Iteration 12 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-08 13:26:37,240 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-08 13:26:37,240 INFO L85 PathProgramCache]: Analyzing trace with hash -132947769, now seen corresponding path program 9 times [2022-04-08 13:26:37,240 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-08 13:26:37,240 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [286077446] [2022-04-08 13:26:41,323 INFO L97 AcceleratorQvasr]: Qvasr could not accelerate loop because java.lang.UnsupportedOperationException: Cannot deal with arrays. [2022-04-08 13:26:41,323 INFO L274 tedInterpolationCore]: Could not compute an accelerate. [2022-04-08 13:26:41,323 INFO L85 PathProgramCache]: Analyzing trace with hash -132947769, now seen corresponding path program 10 times [2022-04-08 13:26:41,323 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-08 13:26:41,323 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [246073243] [2022-04-08 13:26:41,323 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-08 13:26:41,323 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-08 13:26:41,342 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-08 13:26:41,343 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1043073409] [2022-04-08 13:26:41,343 INFO L93 rtionOrderModulation]: Changing assertion order to TERMS_WITH_SMALL_CONSTANTS_FIRST [2022-04-08 13:26:41,343 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:26:41,343 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-08 13:26:41,344 INFO L229 MonitoredProcess]: Starting monitored process 10 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-08 13:26:41,345 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (10)] Waiting until timeout for monitored process [2022-04-08 13:26:41,389 INFO L228 tOrderPrioritization]: Assert order TERMS_WITH_SMALL_CONSTANTS_FIRST issued 0 check-sat command(s) [2022-04-08 13:26:41,389 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-08 13:26:41,390 INFO L263 TraceCheckSpWp]: Trace formula consists of 194 conjuncts, 37 conjunts are in the unsatisfiable core [2022-04-08 13:26:41,403 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:26:41,404 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-08 13:26:41,952 INFO L272 TraceCheckUtils]: 0: Hoare triple {8035#true} call ULTIMATE.init(); {8035#true} is VALID [2022-04-08 13:26:41,952 INFO L290 TraceCheckUtils]: 1: Hoare triple {8035#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {8035#true} is VALID [2022-04-08 13:26:41,952 INFO L290 TraceCheckUtils]: 2: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:26:41,952 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {8035#true} {8035#true} #94#return; {8035#true} is VALID [2022-04-08 13:26:41,953 INFO L272 TraceCheckUtils]: 4: Hoare triple {8035#true} call #t~ret5 := main(); {8035#true} is VALID [2022-04-08 13:26:41,953 INFO L290 TraceCheckUtils]: 5: Hoare triple {8035#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {8035#true} is VALID [2022-04-08 13:26:41,953 INFO L272 TraceCheckUtils]: 6: Hoare triple {8035#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:26:41,953 INFO L290 TraceCheckUtils]: 7: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:26:41,953 INFO L290 TraceCheckUtils]: 8: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:26:41,953 INFO L290 TraceCheckUtils]: 9: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:26:41,953 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {8035#true} {8035#true} #78#return; {8035#true} is VALID [2022-04-08 13:26:41,960 INFO L290 TraceCheckUtils]: 11: Hoare triple {8035#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {8073#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:26:41,960 INFO L290 TraceCheckUtils]: 12: Hoare triple {8073#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !false; {8073#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:26:41,960 INFO L272 TraceCheckUtils]: 13: Hoare triple {8073#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:26:41,960 INFO L290 TraceCheckUtils]: 14: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:26:41,960 INFO L290 TraceCheckUtils]: 15: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:26:41,960 INFO L290 TraceCheckUtils]: 16: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:26:41,961 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {8035#true} {8073#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #80#return; {8073#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:26:41,961 INFO L272 TraceCheckUtils]: 18: Hoare triple {8073#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:26:41,961 INFO L290 TraceCheckUtils]: 19: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:26:41,961 INFO L290 TraceCheckUtils]: 20: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:26:41,961 INFO L290 TraceCheckUtils]: 21: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:26:41,961 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {8035#true} {8073#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #82#return; {8073#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:26:41,961 INFO L272 TraceCheckUtils]: 23: Hoare triple {8073#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:26:41,962 INFO L290 TraceCheckUtils]: 24: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:26:41,962 INFO L290 TraceCheckUtils]: 25: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:26:41,962 INFO L290 TraceCheckUtils]: 26: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:26:41,962 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {8035#true} {8073#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #84#return; {8073#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:26:41,962 INFO L290 TraceCheckUtils]: 28: Hoare triple {8073#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {8125#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:26:41,963 INFO L290 TraceCheckUtils]: 29: Hoare triple {8125#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} assume !false; {8125#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:26:41,963 INFO L272 TraceCheckUtils]: 30: Hoare triple {8125#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:26:41,963 INFO L290 TraceCheckUtils]: 31: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:26:41,963 INFO L290 TraceCheckUtils]: 32: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:26:41,963 INFO L290 TraceCheckUtils]: 33: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:26:41,963 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {8035#true} {8125#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #80#return; {8125#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:26:41,964 INFO L272 TraceCheckUtils]: 35: Hoare triple {8125#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:26:41,964 INFO L290 TraceCheckUtils]: 36: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:26:41,964 INFO L290 TraceCheckUtils]: 37: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:26:41,964 INFO L290 TraceCheckUtils]: 38: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:26:41,964 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {8035#true} {8125#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #82#return; {8125#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:26:41,964 INFO L272 TraceCheckUtils]: 40: Hoare triple {8125#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:26:41,964 INFO L290 TraceCheckUtils]: 41: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:26:41,964 INFO L290 TraceCheckUtils]: 42: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:26:41,964 INFO L290 TraceCheckUtils]: 43: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:26:41,965 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {8035#true} {8125#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #84#return; {8125#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:26:41,965 INFO L290 TraceCheckUtils]: 45: Hoare triple {8125#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:26:41,966 INFO L290 TraceCheckUtils]: 46: Hoare triple {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} assume !false; {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:26:41,966 INFO L272 TraceCheckUtils]: 47: Hoare triple {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:26:41,966 INFO L290 TraceCheckUtils]: 48: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:26:41,966 INFO L290 TraceCheckUtils]: 49: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:26:41,966 INFO L290 TraceCheckUtils]: 50: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:26:41,966 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {8035#true} {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} #80#return; {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:26:41,966 INFO L272 TraceCheckUtils]: 52: Hoare triple {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:26:41,966 INFO L290 TraceCheckUtils]: 53: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:26:41,966 INFO L290 TraceCheckUtils]: 54: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:26:41,967 INFO L290 TraceCheckUtils]: 55: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:26:41,967 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {8035#true} {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} #82#return; {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:26:41,967 INFO L272 TraceCheckUtils]: 57: Hoare triple {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:26:41,967 INFO L290 TraceCheckUtils]: 58: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:26:41,967 INFO L290 TraceCheckUtils]: 59: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:26:41,967 INFO L290 TraceCheckUtils]: 60: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:26:41,968 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {8035#true} {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} #84#return; {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:26:41,968 INFO L290 TraceCheckUtils]: 62: Hoare triple {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} assume !(~r~0 >= ~d~0); {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:26:41,968 INFO L290 TraceCheckUtils]: 63: Hoare triple {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} assume !false; {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:26:41,968 INFO L272 TraceCheckUtils]: 64: Hoare triple {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:26:41,968 INFO L290 TraceCheckUtils]: 65: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:26:41,969 INFO L290 TraceCheckUtils]: 66: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:26:41,969 INFO L290 TraceCheckUtils]: 67: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:26:41,969 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {8035#true} {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} #86#return; {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:26:41,969 INFO L272 TraceCheckUtils]: 69: Hoare triple {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:26:41,969 INFO L290 TraceCheckUtils]: 70: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:26:41,969 INFO L290 TraceCheckUtils]: 71: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:26:41,969 INFO L290 TraceCheckUtils]: 72: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:26:41,970 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {8035#true} {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} #88#return; {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:26:41,970 INFO L290 TraceCheckUtils]: 74: Hoare triple {8177#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {8125#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:26:41,971 INFO L290 TraceCheckUtils]: 75: Hoare triple {8125#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {8268#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} is VALID [2022-04-08 13:26:41,971 INFO L290 TraceCheckUtils]: 76: Hoare triple {8268#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} assume !false; {8268#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} is VALID [2022-04-08 13:26:41,971 INFO L272 TraceCheckUtils]: 77: Hoare triple {8268#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:26:41,971 INFO L290 TraceCheckUtils]: 78: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:26:41,971 INFO L290 TraceCheckUtils]: 79: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:26:41,971 INFO L290 TraceCheckUtils]: 80: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:26:41,972 INFO L284 TraceCheckUtils]: 81: Hoare quadruple {8035#true} {8268#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} #86#return; {8268#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} is VALID [2022-04-08 13:26:41,972 INFO L272 TraceCheckUtils]: 82: Hoare triple {8268#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:26:41,972 INFO L290 TraceCheckUtils]: 83: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:26:41,972 INFO L290 TraceCheckUtils]: 84: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:26:41,972 INFO L290 TraceCheckUtils]: 85: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:26:41,972 INFO L284 TraceCheckUtils]: 86: Hoare quadruple {8035#true} {8268#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} #88#return; {8268#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} is VALID [2022-04-08 13:26:41,973 INFO L290 TraceCheckUtils]: 87: Hoare triple {8268#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~B~0 1) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {8305#(and (= main_~p~0 (div main_~q~0 2)) (= main_~q~0 2) (= (+ (* (- 2) main_~B~0) main_~A~0) main_~r~0) (= (div (* main_~B~0 2) 2) main_~d~0) (= main_~B~0 1))} is VALID [2022-04-08 13:26:41,974 INFO L290 TraceCheckUtils]: 88: Hoare triple {8305#(and (= main_~p~0 (div main_~q~0 2)) (= main_~q~0 2) (= (+ (* (- 2) main_~B~0) main_~A~0) main_~r~0) (= (div (* main_~B~0 2) 2) main_~d~0) (= main_~B~0 1))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {8309#(and (= (div (* main_~B~0 2) 2) (+ (* (- 2) main_~B~0) main_~A~0 (* (- 1) main_~r~0))) (= (+ (- 2) main_~q~0) 1) (= main_~B~0 1))} is VALID [2022-04-08 13:26:41,974 INFO L290 TraceCheckUtils]: 89: Hoare triple {8309#(and (= (div (* main_~B~0 2) 2) (+ (* (- 2) main_~B~0) main_~A~0 (* (- 1) main_~r~0))) (= (+ (- 2) main_~q~0) 1) (= main_~B~0 1))} assume !false; {8309#(and (= (div (* main_~B~0 2) 2) (+ (* (- 2) main_~B~0) main_~A~0 (* (- 1) main_~r~0))) (= (+ (- 2) main_~q~0) 1) (= main_~B~0 1))} is VALID [2022-04-08 13:26:41,975 INFO L272 TraceCheckUtils]: 90: Hoare triple {8309#(and (= (div (* main_~B~0 2) 2) (+ (* (- 2) main_~B~0) main_~A~0 (* (- 1) main_~r~0))) (= (+ (- 2) main_~q~0) 1) (= main_~B~0 1))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {8316#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:26:41,975 INFO L290 TraceCheckUtils]: 91: Hoare triple {8316#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {8320#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:26:41,975 INFO L290 TraceCheckUtils]: 92: Hoare triple {8320#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {8036#false} is VALID [2022-04-08 13:26:41,975 INFO L290 TraceCheckUtils]: 93: Hoare triple {8036#false} assume !false; {8036#false} is VALID [2022-04-08 13:26:41,976 INFO L134 CoverageAnalysis]: Checked inductivity of 362 backedges. 26 proven. 24 refuted. 0 times theorem prover too weak. 312 trivial. 0 not checked. [2022-04-08 13:26:41,976 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-08 13:27:15,076 INFO L290 TraceCheckUtils]: 93: Hoare triple {8036#false} assume !false; {8036#false} is VALID [2022-04-08 13:27:15,077 INFO L290 TraceCheckUtils]: 92: Hoare triple {8320#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {8036#false} is VALID [2022-04-08 13:27:15,077 INFO L290 TraceCheckUtils]: 91: Hoare triple {8316#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {8320#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:27:15,078 INFO L272 TraceCheckUtils]: 90: Hoare triple {8336#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {8316#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:27:15,078 INFO L290 TraceCheckUtils]: 89: Hoare triple {8336#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} assume !false; {8336#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:27:15,090 INFO L290 TraceCheckUtils]: 88: Hoare triple {8343#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {8336#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:27:15,109 INFO L290 TraceCheckUtils]: 87: Hoare triple {8347#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {8343#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} is VALID [2022-04-08 13:27:15,110 INFO L284 TraceCheckUtils]: 86: Hoare quadruple {8035#true} {8347#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} #88#return; {8347#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:27:15,110 INFO L290 TraceCheckUtils]: 85: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:27:15,110 INFO L290 TraceCheckUtils]: 84: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:27:15,110 INFO L290 TraceCheckUtils]: 83: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:27:15,110 INFO L272 TraceCheckUtils]: 82: Hoare triple {8347#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:27:15,110 INFO L284 TraceCheckUtils]: 81: Hoare quadruple {8035#true} {8347#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} #86#return; {8347#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:27:15,110 INFO L290 TraceCheckUtils]: 80: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:27:15,111 INFO L290 TraceCheckUtils]: 79: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:27:15,111 INFO L290 TraceCheckUtils]: 78: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:27:15,111 INFO L272 TraceCheckUtils]: 77: Hoare triple {8347#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:27:15,112 INFO L290 TraceCheckUtils]: 76: Hoare triple {8347#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} assume !false; {8347#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:27:15,133 INFO L290 TraceCheckUtils]: 75: Hoare triple {8384#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {8347#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:27:15,450 INFO L290 TraceCheckUtils]: 74: Hoare triple {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {8384#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} is VALID [2022-04-08 13:27:15,451 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {8035#true} {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} #88#return; {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:27:15,451 INFO L290 TraceCheckUtils]: 72: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:27:15,451 INFO L290 TraceCheckUtils]: 71: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:27:15,451 INFO L290 TraceCheckUtils]: 70: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:27:15,452 INFO L272 TraceCheckUtils]: 69: Hoare triple {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:27:15,452 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {8035#true} {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} #86#return; {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:27:15,453 INFO L290 TraceCheckUtils]: 67: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:27:15,453 INFO L290 TraceCheckUtils]: 66: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:27:15,453 INFO L290 TraceCheckUtils]: 65: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:27:15,453 INFO L272 TraceCheckUtils]: 64: Hoare triple {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:27:15,456 INFO L290 TraceCheckUtils]: 63: Hoare triple {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} assume !false; {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:27:15,459 INFO L290 TraceCheckUtils]: 62: Hoare triple {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} assume !(~r~0 >= ~d~0); {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:27:15,460 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {8035#true} {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} #84#return; {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:27:15,460 INFO L290 TraceCheckUtils]: 60: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:27:15,460 INFO L290 TraceCheckUtils]: 59: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:27:15,460 INFO L290 TraceCheckUtils]: 58: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:27:15,461 INFO L272 TraceCheckUtils]: 57: Hoare triple {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:27:15,470 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {8035#true} {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} #82#return; {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:27:15,470 INFO L290 TraceCheckUtils]: 55: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:27:15,470 INFO L290 TraceCheckUtils]: 54: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:27:15,470 INFO L290 TraceCheckUtils]: 53: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:27:15,470 INFO L272 TraceCheckUtils]: 52: Hoare triple {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:27:15,471 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {8035#true} {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} #80#return; {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:27:15,471 INFO L290 TraceCheckUtils]: 50: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:27:15,471 INFO L290 TraceCheckUtils]: 49: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:27:15,471 INFO L290 TraceCheckUtils]: 48: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:27:15,471 INFO L272 TraceCheckUtils]: 47: Hoare triple {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:27:15,474 INFO L290 TraceCheckUtils]: 46: Hoare triple {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} assume !false; {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:27:15,594 INFO L290 TraceCheckUtils]: 45: Hoare triple {8384#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {8388#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:27:15,595 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {8035#true} {8384#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} #84#return; {8384#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} is VALID [2022-04-08 13:27:15,595 INFO L290 TraceCheckUtils]: 43: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:27:15,595 INFO L290 TraceCheckUtils]: 42: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:27:15,595 INFO L290 TraceCheckUtils]: 41: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:27:15,595 INFO L272 TraceCheckUtils]: 40: Hoare triple {8384#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:27:15,596 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {8035#true} {8384#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} #82#return; {8384#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} is VALID [2022-04-08 13:27:15,596 INFO L290 TraceCheckUtils]: 38: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:27:15,596 INFO L290 TraceCheckUtils]: 37: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:27:15,596 INFO L290 TraceCheckUtils]: 36: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:27:15,596 INFO L272 TraceCheckUtils]: 35: Hoare triple {8384#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:27:15,597 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {8035#true} {8384#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} #80#return; {8384#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} is VALID [2022-04-08 13:27:15,597 INFO L290 TraceCheckUtils]: 33: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:27:15,597 INFO L290 TraceCheckUtils]: 32: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:27:15,597 INFO L290 TraceCheckUtils]: 31: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:27:15,597 INFO L272 TraceCheckUtils]: 30: Hoare triple {8384#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:27:15,598 INFO L290 TraceCheckUtils]: 29: Hoare triple {8384#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} assume !false; {8384#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} is VALID [2022-04-08 13:27:15,619 INFO L290 TraceCheckUtils]: 28: Hoare triple {8527#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {8384#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} is VALID [2022-04-08 13:27:15,619 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {8035#true} {8527#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} #84#return; {8527#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} is VALID [2022-04-08 13:27:15,620 INFO L290 TraceCheckUtils]: 26: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:27:15,620 INFO L290 TraceCheckUtils]: 25: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:27:15,620 INFO L290 TraceCheckUtils]: 24: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:27:15,620 INFO L272 TraceCheckUtils]: 23: Hoare triple {8527#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:27:15,620 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {8035#true} {8527#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} #82#return; {8527#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} is VALID [2022-04-08 13:27:15,620 INFO L290 TraceCheckUtils]: 21: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:27:15,620 INFO L290 TraceCheckUtils]: 20: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:27:15,620 INFO L290 TraceCheckUtils]: 19: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:27:15,620 INFO L272 TraceCheckUtils]: 18: Hoare triple {8527#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:27:15,621 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {8035#true} {8527#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} #80#return; {8527#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} is VALID [2022-04-08 13:27:15,621 INFO L290 TraceCheckUtils]: 16: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:27:15,621 INFO L290 TraceCheckUtils]: 15: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:27:15,621 INFO L290 TraceCheckUtils]: 14: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:27:15,621 INFO L272 TraceCheckUtils]: 13: Hoare triple {8527#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:27:15,621 INFO L290 TraceCheckUtils]: 12: Hoare triple {8527#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} assume !false; {8527#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} is VALID [2022-04-08 13:27:15,622 INFO L290 TraceCheckUtils]: 11: Hoare triple {8035#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {8527#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} is VALID [2022-04-08 13:27:15,622 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {8035#true} {8035#true} #78#return; {8035#true} is VALID [2022-04-08 13:27:15,622 INFO L290 TraceCheckUtils]: 9: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:27:15,622 INFO L290 TraceCheckUtils]: 8: Hoare triple {8035#true} assume !(0 == ~cond); {8035#true} is VALID [2022-04-08 13:27:15,622 INFO L290 TraceCheckUtils]: 7: Hoare triple {8035#true} ~cond := #in~cond; {8035#true} is VALID [2022-04-08 13:27:15,622 INFO L272 TraceCheckUtils]: 6: Hoare triple {8035#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {8035#true} is VALID [2022-04-08 13:27:15,622 INFO L290 TraceCheckUtils]: 5: Hoare triple {8035#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {8035#true} is VALID [2022-04-08 13:27:15,622 INFO L272 TraceCheckUtils]: 4: Hoare triple {8035#true} call #t~ret5 := main(); {8035#true} is VALID [2022-04-08 13:27:15,622 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {8035#true} {8035#true} #94#return; {8035#true} is VALID [2022-04-08 13:27:15,622 INFO L290 TraceCheckUtils]: 2: Hoare triple {8035#true} assume true; {8035#true} is VALID [2022-04-08 13:27:15,622 INFO L290 TraceCheckUtils]: 1: Hoare triple {8035#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {8035#true} is VALID [2022-04-08 13:27:15,622 INFO L272 TraceCheckUtils]: 0: Hoare triple {8035#true} call ULTIMATE.init(); {8035#true} is VALID [2022-04-08 13:27:15,623 INFO L134 CoverageAnalysis]: Checked inductivity of 362 backedges. 26 proven. 24 refuted. 0 times theorem prover too weak. 312 trivial. 0 not checked. [2022-04-08 13:27:15,623 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-08 13:27:15,623 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [246073243] [2022-04-08 13:27:15,624 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-08 13:27:15,624 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1043073409] [2022-04-08 13:27:15,624 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1043073409] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-08 13:27:15,624 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-08 13:27:15,624 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [10, 10] total 16 [2022-04-08 13:27:15,624 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-08 13:27:15,624 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [286077446] [2022-04-08 13:27:15,624 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [286077446] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:27:15,624 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:27:15,624 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [10] imperfect sequences [] total 10 [2022-04-08 13:27:15,624 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1596405343] [2022-04-08 13:27:15,624 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-08 13:27:15,625 INFO L78 Accepts]: Start accepts. Automaton has has 10 states, 10 states have (on average 2.6) internal successors, (26), 9 states have internal predecessors, (26), 6 states have call successors, (17), 2 states have call predecessors, (17), 1 states have return successors, (15), 5 states have call predecessors, (15), 5 states have call successors, (15) Word has length 94 [2022-04-08 13:27:15,625 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-08 13:27:15,625 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 10 states, 10 states have (on average 2.6) internal successors, (26), 9 states have internal predecessors, (26), 6 states have call successors, (17), 2 states have call predecessors, (17), 1 states have return successors, (15), 5 states have call predecessors, (15), 5 states have call successors, (15) [2022-04-08 13:27:15,669 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 58 edges. 58 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:27:15,669 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 10 states [2022-04-08 13:27:15,669 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-08 13:27:15,669 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 10 interpolants. [2022-04-08 13:27:15,670 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=60, Invalid=179, Unknown=1, NotChecked=0, Total=240 [2022-04-08 13:27:15,670 INFO L87 Difference]: Start difference. First operand 130 states and 158 transitions. Second operand has 10 states, 10 states have (on average 2.6) internal successors, (26), 9 states have internal predecessors, (26), 6 states have call successors, (17), 2 states have call predecessors, (17), 1 states have return successors, (15), 5 states have call predecessors, (15), 5 states have call successors, (15) [2022-04-08 13:27:16,818 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:27:16,818 INFO L93 Difference]: Finished difference Result 164 states and 189 transitions. [2022-04-08 13:27:16,818 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 10 states. [2022-04-08 13:27:16,818 INFO L78 Accepts]: Start accepts. Automaton has has 10 states, 10 states have (on average 2.6) internal successors, (26), 9 states have internal predecessors, (26), 6 states have call successors, (17), 2 states have call predecessors, (17), 1 states have return successors, (15), 5 states have call predecessors, (15), 5 states have call successors, (15) Word has length 94 [2022-04-08 13:27:16,819 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-08 13:27:16,822 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 10 states, 10 states have (on average 2.6) internal successors, (26), 9 states have internal predecessors, (26), 6 states have call successors, (17), 2 states have call predecessors, (17), 1 states have return successors, (15), 5 states have call predecessors, (15), 5 states have call successors, (15) [2022-04-08 13:27:16,823 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 10 states to 10 states and 105 transitions. [2022-04-08 13:27:16,823 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 10 states, 10 states have (on average 2.6) internal successors, (26), 9 states have internal predecessors, (26), 6 states have call successors, (17), 2 states have call predecessors, (17), 1 states have return successors, (15), 5 states have call predecessors, (15), 5 states have call successors, (15) [2022-04-08 13:27:16,824 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 10 states to 10 states and 105 transitions. [2022-04-08 13:27:16,825 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 10 states and 105 transitions. [2022-04-08 13:27:16,915 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 105 edges. 105 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:27:16,917 INFO L225 Difference]: With dead ends: 164 [2022-04-08 13:27:16,917 INFO L226 Difference]: Without dead ends: 157 [2022-04-08 13:27:16,918 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 188 GetRequests, 170 SyntacticMatches, 3 SemanticMatches, 15 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 6 ImplicationChecksByTransitivity, 6.6s TimeCoverageRelationStatistics Valid=64, Invalid=207, Unknown=1, NotChecked=0, Total=272 [2022-04-08 13:27:16,918 INFO L913 BasicCegarLoop]: 53 mSDtfsCounter, 11 mSDsluCounter, 213 mSDsCounter, 0 mSdLazyCounter, 457 mSolverCounterSat, 19 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.5s Time, 0 mProtectedPredicate, 0 mProtectedAction, 17 SdHoareTripleChecker+Valid, 266 SdHoareTripleChecker+Invalid, 476 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 19 IncrementalHoareTripleChecker+Valid, 457 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.5s IncrementalHoareTripleChecker+Time [2022-04-08 13:27:16,918 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [17 Valid, 266 Invalid, 476 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [19 Valid, 457 Invalid, 0 Unknown, 0 Unchecked, 0.5s Time] [2022-04-08 13:27:16,919 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 157 states. [2022-04-08 13:27:17,012 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 157 to 154. [2022-04-08 13:27:17,012 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-08 13:27:17,012 INFO L82 GeneralOperation]: Start isEquivalent. First operand 157 states. Second operand has 154 states, 96 states have (on average 1.1041666666666667) internal successors, (106), 100 states have internal predecessors, (106), 36 states have call successors, (36), 22 states have call predecessors, (36), 21 states have return successors, (33), 31 states have call predecessors, (33), 33 states have call successors, (33) [2022-04-08 13:27:17,013 INFO L74 IsIncluded]: Start isIncluded. First operand 157 states. Second operand has 154 states, 96 states have (on average 1.1041666666666667) internal successors, (106), 100 states have internal predecessors, (106), 36 states have call successors, (36), 22 states have call predecessors, (36), 21 states have return successors, (33), 31 states have call predecessors, (33), 33 states have call successors, (33) [2022-04-08 13:27:17,013 INFO L87 Difference]: Start difference. First operand 157 states. Second operand has 154 states, 96 states have (on average 1.1041666666666667) internal successors, (106), 100 states have internal predecessors, (106), 36 states have call successors, (36), 22 states have call predecessors, (36), 21 states have return successors, (33), 31 states have call predecessors, (33), 33 states have call successors, (33) [2022-04-08 13:27:17,015 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:27:17,015 INFO L93 Difference]: Finished difference Result 157 states and 179 transitions. [2022-04-08 13:27:17,015 INFO L276 IsEmpty]: Start isEmpty. Operand 157 states and 179 transitions. [2022-04-08 13:27:17,016 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:27:17,016 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:27:17,016 INFO L74 IsIncluded]: Start isIncluded. First operand has 154 states, 96 states have (on average 1.1041666666666667) internal successors, (106), 100 states have internal predecessors, (106), 36 states have call successors, (36), 22 states have call predecessors, (36), 21 states have return successors, (33), 31 states have call predecessors, (33), 33 states have call successors, (33) Second operand 157 states. [2022-04-08 13:27:17,016 INFO L87 Difference]: Start difference. First operand has 154 states, 96 states have (on average 1.1041666666666667) internal successors, (106), 100 states have internal predecessors, (106), 36 states have call successors, (36), 22 states have call predecessors, (36), 21 states have return successors, (33), 31 states have call predecessors, (33), 33 states have call successors, (33) Second operand 157 states. [2022-04-08 13:27:17,019 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:27:17,019 INFO L93 Difference]: Finished difference Result 157 states and 179 transitions. [2022-04-08 13:27:17,019 INFO L276 IsEmpty]: Start isEmpty. Operand 157 states and 179 transitions. [2022-04-08 13:27:17,019 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:27:17,019 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:27:17,019 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-08 13:27:17,019 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-08 13:27:17,019 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 154 states, 96 states have (on average 1.1041666666666667) internal successors, (106), 100 states have internal predecessors, (106), 36 states have call successors, (36), 22 states have call predecessors, (36), 21 states have return successors, (33), 31 states have call predecessors, (33), 33 states have call successors, (33) [2022-04-08 13:27:17,022 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 154 states to 154 states and 175 transitions. [2022-04-08 13:27:17,022 INFO L78 Accepts]: Start accepts. Automaton has 154 states and 175 transitions. Word has length 94 [2022-04-08 13:27:17,022 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-08 13:27:17,022 INFO L478 AbstractCegarLoop]: Abstraction has 154 states and 175 transitions. [2022-04-08 13:27:17,022 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 10 states, 10 states have (on average 2.6) internal successors, (26), 9 states have internal predecessors, (26), 6 states have call successors, (17), 2 states have call predecessors, (17), 1 states have return successors, (15), 5 states have call predecessors, (15), 5 states have call successors, (15) [2022-04-08 13:27:17,022 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 154 states and 175 transitions. [2022-04-08 13:27:17,208 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 175 edges. 175 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:27:17,208 INFO L276 IsEmpty]: Start isEmpty. Operand 154 states and 175 transitions. [2022-04-08 13:27:17,209 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 104 [2022-04-08 13:27:17,209 INFO L491 BasicCegarLoop]: Found error trace [2022-04-08 13:27:17,209 INFO L499 BasicCegarLoop]: trace histogram [16, 15, 15, 4, 4, 4, 4, 4, 4, 4, 3, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-08 13:27:17,225 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (10)] Forceful destruction successful, exit code 0 [2022-04-08 13:27:17,421 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable11,10 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:27:17,422 INFO L403 AbstractCegarLoop]: === Iteration 13 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-08 13:27:17,422 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-08 13:27:17,422 INFO L85 PathProgramCache]: Analyzing trace with hash -321511332, now seen corresponding path program 11 times [2022-04-08 13:27:17,422 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-08 13:27:17,422 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [1365139620] [2022-04-08 13:27:21,145 INFO L97 AcceleratorQvasr]: Qvasr could not accelerate loop because java.lang.UnsupportedOperationException: Cannot deal with arrays. [2022-04-08 13:27:21,145 INFO L274 tedInterpolationCore]: Could not compute an accelerate. [2022-04-08 13:27:21,145 INFO L85 PathProgramCache]: Analyzing trace with hash -321511332, now seen corresponding path program 12 times [2022-04-08 13:27:21,146 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-08 13:27:21,146 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [416550877] [2022-04-08 13:27:21,146 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-08 13:27:21,146 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-08 13:27:21,154 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-08 13:27:21,155 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [103034097] [2022-04-08 13:27:21,155 INFO L93 rtionOrderModulation]: Changing assertion order to MIX_INSIDE_OUTSIDE [2022-04-08 13:27:21,155 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:27:21,155 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-08 13:27:21,156 INFO L229 MonitoredProcess]: Starting monitored process 11 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-08 13:27:21,157 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (11)] Waiting until timeout for monitored process [2022-04-08 13:27:21,208 INFO L228 tOrderPrioritization]: Assert order MIX_INSIDE_OUTSIDE issued 5 check-sat command(s) [2022-04-08 13:27:21,208 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-08 13:27:21,209 INFO L263 TraceCheckSpWp]: Trace formula consists of 167 conjuncts, 18 conjunts are in the unsatisfiable core [2022-04-08 13:27:21,223 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:27:21,224 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-08 13:27:21,680 INFO L272 TraceCheckUtils]: 0: Hoare triple {9566#true} call ULTIMATE.init(); {9566#true} is VALID [2022-04-08 13:27:21,680 INFO L290 TraceCheckUtils]: 1: Hoare triple {9566#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {9566#true} is VALID [2022-04-08 13:27:21,680 INFO L290 TraceCheckUtils]: 2: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:21,680 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {9566#true} {9566#true} #94#return; {9566#true} is VALID [2022-04-08 13:27:21,680 INFO L272 TraceCheckUtils]: 4: Hoare triple {9566#true} call #t~ret5 := main(); {9566#true} is VALID [2022-04-08 13:27:21,680 INFO L290 TraceCheckUtils]: 5: Hoare triple {9566#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {9566#true} is VALID [2022-04-08 13:27:21,680 INFO L272 TraceCheckUtils]: 6: Hoare triple {9566#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:21,681 INFO L290 TraceCheckUtils]: 7: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:21,681 INFO L290 TraceCheckUtils]: 8: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:21,681 INFO L290 TraceCheckUtils]: 9: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:21,681 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {9566#true} {9566#true} #78#return; {9566#true} is VALID [2022-04-08 13:27:21,681 INFO L290 TraceCheckUtils]: 11: Hoare triple {9566#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {9604#(= main_~B~0 1)} is VALID [2022-04-08 13:27:21,681 INFO L290 TraceCheckUtils]: 12: Hoare triple {9604#(= main_~B~0 1)} assume !false; {9604#(= main_~B~0 1)} is VALID [2022-04-08 13:27:21,681 INFO L272 TraceCheckUtils]: 13: Hoare triple {9604#(= main_~B~0 1)} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:21,681 INFO L290 TraceCheckUtils]: 14: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:21,681 INFO L290 TraceCheckUtils]: 15: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:21,681 INFO L290 TraceCheckUtils]: 16: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:21,682 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {9566#true} {9604#(= main_~B~0 1)} #80#return; {9604#(= main_~B~0 1)} is VALID [2022-04-08 13:27:21,682 INFO L272 TraceCheckUtils]: 18: Hoare triple {9604#(= main_~B~0 1)} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:21,682 INFO L290 TraceCheckUtils]: 19: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:21,682 INFO L290 TraceCheckUtils]: 20: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:21,682 INFO L290 TraceCheckUtils]: 21: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:21,682 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {9566#true} {9604#(= main_~B~0 1)} #82#return; {9604#(= main_~B~0 1)} is VALID [2022-04-08 13:27:21,683 INFO L272 TraceCheckUtils]: 23: Hoare triple {9604#(= main_~B~0 1)} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:21,683 INFO L290 TraceCheckUtils]: 24: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:21,683 INFO L290 TraceCheckUtils]: 25: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:21,683 INFO L290 TraceCheckUtils]: 26: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:21,683 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {9566#true} {9604#(= main_~B~0 1)} #84#return; {9604#(= main_~B~0 1)} is VALID [2022-04-08 13:27:21,683 INFO L290 TraceCheckUtils]: 28: Hoare triple {9604#(= main_~B~0 1)} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {9604#(= main_~B~0 1)} is VALID [2022-04-08 13:27:21,684 INFO L290 TraceCheckUtils]: 29: Hoare triple {9604#(= main_~B~0 1)} assume !false; {9604#(= main_~B~0 1)} is VALID [2022-04-08 13:27:21,684 INFO L272 TraceCheckUtils]: 30: Hoare triple {9604#(= main_~B~0 1)} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:21,684 INFO L290 TraceCheckUtils]: 31: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:21,684 INFO L290 TraceCheckUtils]: 32: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:21,684 INFO L290 TraceCheckUtils]: 33: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:21,684 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {9566#true} {9604#(= main_~B~0 1)} #80#return; {9604#(= main_~B~0 1)} is VALID [2022-04-08 13:27:21,684 INFO L272 TraceCheckUtils]: 35: Hoare triple {9604#(= main_~B~0 1)} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:21,684 INFO L290 TraceCheckUtils]: 36: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:21,684 INFO L290 TraceCheckUtils]: 37: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:21,684 INFO L290 TraceCheckUtils]: 38: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:21,685 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {9566#true} {9604#(= main_~B~0 1)} #82#return; {9604#(= main_~B~0 1)} is VALID [2022-04-08 13:27:21,685 INFO L272 TraceCheckUtils]: 40: Hoare triple {9604#(= main_~B~0 1)} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:21,685 INFO L290 TraceCheckUtils]: 41: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:21,685 INFO L290 TraceCheckUtils]: 42: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:21,685 INFO L290 TraceCheckUtils]: 43: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:21,685 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {9566#true} {9604#(= main_~B~0 1)} #84#return; {9604#(= main_~B~0 1)} is VALID [2022-04-08 13:27:21,686 INFO L290 TraceCheckUtils]: 45: Hoare triple {9604#(= main_~B~0 1)} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {9604#(= main_~B~0 1)} is VALID [2022-04-08 13:27:21,686 INFO L290 TraceCheckUtils]: 46: Hoare triple {9604#(= main_~B~0 1)} assume !false; {9604#(= main_~B~0 1)} is VALID [2022-04-08 13:27:21,686 INFO L272 TraceCheckUtils]: 47: Hoare triple {9604#(= main_~B~0 1)} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:21,686 INFO L290 TraceCheckUtils]: 48: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:21,686 INFO L290 TraceCheckUtils]: 49: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:21,686 INFO L290 TraceCheckUtils]: 50: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:21,686 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {9566#true} {9604#(= main_~B~0 1)} #80#return; {9604#(= main_~B~0 1)} is VALID [2022-04-08 13:27:21,686 INFO L272 TraceCheckUtils]: 52: Hoare triple {9604#(= main_~B~0 1)} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:21,686 INFO L290 TraceCheckUtils]: 53: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:21,687 INFO L290 TraceCheckUtils]: 54: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:21,687 INFO L290 TraceCheckUtils]: 55: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:21,687 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {9566#true} {9604#(= main_~B~0 1)} #82#return; {9604#(= main_~B~0 1)} is VALID [2022-04-08 13:27:21,687 INFO L272 TraceCheckUtils]: 57: Hoare triple {9604#(= main_~B~0 1)} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:21,687 INFO L290 TraceCheckUtils]: 58: Hoare triple {9566#true} ~cond := #in~cond; {9746#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:27:21,687 INFO L290 TraceCheckUtils]: 59: Hoare triple {9746#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {9750#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:27:21,688 INFO L290 TraceCheckUtils]: 60: Hoare triple {9750#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {9750#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:27:21,688 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {9750#(not (= |__VERIFIER_assert_#in~cond| 0))} {9604#(= main_~B~0 1)} #84#return; {9757#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~B~0 1))} is VALID [2022-04-08 13:27:21,689 INFO L290 TraceCheckUtils]: 62: Hoare triple {9757#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~B~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:27:21,689 INFO L290 TraceCheckUtils]: 63: Hoare triple {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} assume !false; {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:27:21,689 INFO L272 TraceCheckUtils]: 64: Hoare triple {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:21,690 INFO L290 TraceCheckUtils]: 65: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:21,690 INFO L290 TraceCheckUtils]: 66: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:21,690 INFO L290 TraceCheckUtils]: 67: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:21,690 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {9566#true} {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} #80#return; {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:27:21,690 INFO L272 TraceCheckUtils]: 69: Hoare triple {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:21,690 INFO L290 TraceCheckUtils]: 70: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:21,690 INFO L290 TraceCheckUtils]: 71: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:21,690 INFO L290 TraceCheckUtils]: 72: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:21,691 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {9566#true} {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} #82#return; {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:27:21,691 INFO L272 TraceCheckUtils]: 74: Hoare triple {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:21,691 INFO L290 TraceCheckUtils]: 75: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:21,691 INFO L290 TraceCheckUtils]: 76: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:21,691 INFO L290 TraceCheckUtils]: 77: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:21,696 INFO L284 TraceCheckUtils]: 78: Hoare quadruple {9566#true} {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} #84#return; {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:27:21,696 INFO L290 TraceCheckUtils]: 79: Hoare triple {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} assume !(~r~0 >= ~d~0); {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:27:21,696 INFO L290 TraceCheckUtils]: 80: Hoare triple {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} assume !false; {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:27:21,696 INFO L272 TraceCheckUtils]: 81: Hoare triple {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:21,696 INFO L290 TraceCheckUtils]: 82: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:21,696 INFO L290 TraceCheckUtils]: 83: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:21,696 INFO L290 TraceCheckUtils]: 84: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:21,697 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {9566#true} {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} #86#return; {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:27:21,697 INFO L272 TraceCheckUtils]: 86: Hoare triple {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:21,697 INFO L290 TraceCheckUtils]: 87: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:21,697 INFO L290 TraceCheckUtils]: 88: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:21,697 INFO L290 TraceCheckUtils]: 89: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:21,698 INFO L284 TraceCheckUtils]: 90: Hoare quadruple {9566#true} {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} #88#return; {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:27:21,699 INFO L290 TraceCheckUtils]: 91: Hoare triple {9761#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {9757#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~B~0 1))} is VALID [2022-04-08 13:27:21,699 INFO L290 TraceCheckUtils]: 92: Hoare triple {9757#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~B~0 1))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {9757#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~B~0 1))} is VALID [2022-04-08 13:27:21,699 INFO L290 TraceCheckUtils]: 93: Hoare triple {9757#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~B~0 1))} assume !false; {9757#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~B~0 1))} is VALID [2022-04-08 13:27:21,699 INFO L272 TraceCheckUtils]: 94: Hoare triple {9757#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~B~0 1))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:21,699 INFO L290 TraceCheckUtils]: 95: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:21,699 INFO L290 TraceCheckUtils]: 96: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:21,700 INFO L290 TraceCheckUtils]: 97: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:21,700 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {9566#true} {9757#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~B~0 1))} #86#return; {9757#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~B~0 1))} is VALID [2022-04-08 13:27:21,700 INFO L272 TraceCheckUtils]: 99: Hoare triple {9757#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~B~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {9873#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:27:21,701 INFO L290 TraceCheckUtils]: 100: Hoare triple {9873#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {9877#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:27:21,701 INFO L290 TraceCheckUtils]: 101: Hoare triple {9877#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {9567#false} is VALID [2022-04-08 13:27:21,701 INFO L290 TraceCheckUtils]: 102: Hoare triple {9567#false} assume !false; {9567#false} is VALID [2022-04-08 13:27:21,701 INFO L134 CoverageAnalysis]: Checked inductivity of 483 backedges. 70 proven. 22 refuted. 0 times theorem prover too weak. 391 trivial. 0 not checked. [2022-04-08 13:27:21,701 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-08 13:27:29,206 INFO L290 TraceCheckUtils]: 102: Hoare triple {9567#false} assume !false; {9567#false} is VALID [2022-04-08 13:27:29,206 INFO L290 TraceCheckUtils]: 101: Hoare triple {9877#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {9567#false} is VALID [2022-04-08 13:27:29,207 INFO L290 TraceCheckUtils]: 100: Hoare triple {9873#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {9877#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:27:29,207 INFO L272 TraceCheckUtils]: 99: Hoare triple {9893#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {9873#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:27:29,208 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {9566#true} {9893#(= (* main_~B~0 main_~p~0) main_~d~0)} #86#return; {9893#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:27:29,208 INFO L290 TraceCheckUtils]: 97: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:29,208 INFO L290 TraceCheckUtils]: 96: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:29,208 INFO L290 TraceCheckUtils]: 95: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:29,208 INFO L272 TraceCheckUtils]: 94: Hoare triple {9893#(= (* main_~B~0 main_~p~0) main_~d~0)} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:29,208 INFO L290 TraceCheckUtils]: 93: Hoare triple {9893#(= (* main_~B~0 main_~p~0) main_~d~0)} assume !false; {9893#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:27:29,209 INFO L290 TraceCheckUtils]: 92: Hoare triple {9893#(= (* main_~B~0 main_~p~0) main_~d~0)} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {9893#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:27:29,224 INFO L290 TraceCheckUtils]: 91: Hoare triple {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {9893#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:27:29,225 INFO L284 TraceCheckUtils]: 90: Hoare quadruple {9566#true} {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} #88#return; {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:27:29,225 INFO L290 TraceCheckUtils]: 89: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:29,225 INFO L290 TraceCheckUtils]: 88: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:29,225 INFO L290 TraceCheckUtils]: 87: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:29,225 INFO L272 TraceCheckUtils]: 86: Hoare triple {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:29,226 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {9566#true} {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} #86#return; {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:27:29,226 INFO L290 TraceCheckUtils]: 84: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:29,226 INFO L290 TraceCheckUtils]: 83: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:29,226 INFO L290 TraceCheckUtils]: 82: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:29,226 INFO L272 TraceCheckUtils]: 81: Hoare triple {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:29,227 INFO L290 TraceCheckUtils]: 80: Hoare triple {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} assume !false; {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:27:29,228 INFO L290 TraceCheckUtils]: 79: Hoare triple {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} assume !(~r~0 >= ~d~0); {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:27:29,228 INFO L284 TraceCheckUtils]: 78: Hoare quadruple {9566#true} {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} #84#return; {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:27:29,228 INFO L290 TraceCheckUtils]: 77: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:29,228 INFO L290 TraceCheckUtils]: 76: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:29,228 INFO L290 TraceCheckUtils]: 75: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:29,228 INFO L272 TraceCheckUtils]: 74: Hoare triple {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:29,229 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {9566#true} {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} #82#return; {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:27:29,229 INFO L290 TraceCheckUtils]: 72: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:29,229 INFO L290 TraceCheckUtils]: 71: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:29,229 INFO L290 TraceCheckUtils]: 70: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:29,229 INFO L272 TraceCheckUtils]: 69: Hoare triple {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:29,229 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {9566#true} {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} #80#return; {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:27:29,230 INFO L290 TraceCheckUtils]: 67: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:29,230 INFO L290 TraceCheckUtils]: 66: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:29,230 INFO L290 TraceCheckUtils]: 65: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:29,230 INFO L272 TraceCheckUtils]: 64: Hoare triple {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:29,230 INFO L290 TraceCheckUtils]: 63: Hoare triple {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} assume !false; {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:27:29,235 INFO L290 TraceCheckUtils]: 62: Hoare triple {9893#(= (* main_~B~0 main_~p~0) main_~d~0)} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {9918#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (div main_~d~0 2) (* main_~B~0 (div main_~p~0 2)))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (div main_~d~0 2) (* main_~B~0 (+ (div main_~p~0 2) 1))))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= (+ (div main_~d~0 2) 1) (* main_~B~0 (+ (div main_~p~0 2) 1))) (= (mod main_~p~0 2) 0)) (or (= (+ (div main_~d~0 2) 1) (* main_~B~0 (div main_~p~0 2))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:27:29,236 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {9750#(not (= |__VERIFIER_assert_#in~cond| 0))} {9566#true} #84#return; {9893#(= (* main_~B~0 main_~p~0) main_~d~0)} is VALID [2022-04-08 13:27:29,236 INFO L290 TraceCheckUtils]: 60: Hoare triple {9750#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {9750#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:27:29,236 INFO L290 TraceCheckUtils]: 59: Hoare triple {10018#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} assume !(0 == ~cond); {9750#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:27:29,237 INFO L290 TraceCheckUtils]: 58: Hoare triple {9566#true} ~cond := #in~cond; {10018#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} is VALID [2022-04-08 13:27:29,237 INFO L272 TraceCheckUtils]: 57: Hoare triple {9566#true} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:29,237 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {9566#true} {9566#true} #82#return; {9566#true} is VALID [2022-04-08 13:27:29,237 INFO L290 TraceCheckUtils]: 55: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:29,237 INFO L290 TraceCheckUtils]: 54: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:29,237 INFO L290 TraceCheckUtils]: 53: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:29,237 INFO L272 TraceCheckUtils]: 52: Hoare triple {9566#true} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:29,237 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {9566#true} {9566#true} #80#return; {9566#true} is VALID [2022-04-08 13:27:29,237 INFO L290 TraceCheckUtils]: 50: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:29,237 INFO L290 TraceCheckUtils]: 49: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:29,237 INFO L290 TraceCheckUtils]: 48: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:29,237 INFO L272 TraceCheckUtils]: 47: Hoare triple {9566#true} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:29,237 INFO L290 TraceCheckUtils]: 46: Hoare triple {9566#true} assume !false; {9566#true} is VALID [2022-04-08 13:27:29,238 INFO L290 TraceCheckUtils]: 45: Hoare triple {9566#true} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {9566#true} is VALID [2022-04-08 13:27:29,238 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {9566#true} {9566#true} #84#return; {9566#true} is VALID [2022-04-08 13:27:29,238 INFO L290 TraceCheckUtils]: 43: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:29,238 INFO L290 TraceCheckUtils]: 42: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:29,238 INFO L290 TraceCheckUtils]: 41: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:29,238 INFO L272 TraceCheckUtils]: 40: Hoare triple {9566#true} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:29,238 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {9566#true} {9566#true} #82#return; {9566#true} is VALID [2022-04-08 13:27:29,238 INFO L290 TraceCheckUtils]: 38: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:29,238 INFO L290 TraceCheckUtils]: 37: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:29,238 INFO L290 TraceCheckUtils]: 36: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:29,238 INFO L272 TraceCheckUtils]: 35: Hoare triple {9566#true} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:29,238 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {9566#true} {9566#true} #80#return; {9566#true} is VALID [2022-04-08 13:27:29,238 INFO L290 TraceCheckUtils]: 33: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:29,238 INFO L290 TraceCheckUtils]: 32: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:29,238 INFO L290 TraceCheckUtils]: 31: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:29,238 INFO L272 TraceCheckUtils]: 30: Hoare triple {9566#true} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:29,238 INFO L290 TraceCheckUtils]: 29: Hoare triple {9566#true} assume !false; {9566#true} is VALID [2022-04-08 13:27:29,238 INFO L290 TraceCheckUtils]: 28: Hoare triple {9566#true} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {9566#true} is VALID [2022-04-08 13:27:29,238 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {9566#true} {9566#true} #84#return; {9566#true} is VALID [2022-04-08 13:27:29,239 INFO L290 TraceCheckUtils]: 26: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:29,239 INFO L290 TraceCheckUtils]: 25: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:29,239 INFO L290 TraceCheckUtils]: 24: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:29,239 INFO L272 TraceCheckUtils]: 23: Hoare triple {9566#true} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:29,239 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {9566#true} {9566#true} #82#return; {9566#true} is VALID [2022-04-08 13:27:29,239 INFO L290 TraceCheckUtils]: 21: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:29,239 INFO L290 TraceCheckUtils]: 20: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:29,239 INFO L290 TraceCheckUtils]: 19: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:29,239 INFO L272 TraceCheckUtils]: 18: Hoare triple {9566#true} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:29,239 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {9566#true} {9566#true} #80#return; {9566#true} is VALID [2022-04-08 13:27:29,239 INFO L290 TraceCheckUtils]: 16: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:29,239 INFO L290 TraceCheckUtils]: 15: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:29,239 INFO L290 TraceCheckUtils]: 14: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:29,239 INFO L272 TraceCheckUtils]: 13: Hoare triple {9566#true} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:29,239 INFO L290 TraceCheckUtils]: 12: Hoare triple {9566#true} assume !false; {9566#true} is VALID [2022-04-08 13:27:29,239 INFO L290 TraceCheckUtils]: 11: Hoare triple {9566#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {9566#true} is VALID [2022-04-08 13:27:29,239 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {9566#true} {9566#true} #78#return; {9566#true} is VALID [2022-04-08 13:27:29,239 INFO L290 TraceCheckUtils]: 9: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:29,240 INFO L290 TraceCheckUtils]: 8: Hoare triple {9566#true} assume !(0 == ~cond); {9566#true} is VALID [2022-04-08 13:27:29,240 INFO L290 TraceCheckUtils]: 7: Hoare triple {9566#true} ~cond := #in~cond; {9566#true} is VALID [2022-04-08 13:27:29,240 INFO L272 TraceCheckUtils]: 6: Hoare triple {9566#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {9566#true} is VALID [2022-04-08 13:27:29,240 INFO L290 TraceCheckUtils]: 5: Hoare triple {9566#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {9566#true} is VALID [2022-04-08 13:27:29,240 INFO L272 TraceCheckUtils]: 4: Hoare triple {9566#true} call #t~ret5 := main(); {9566#true} is VALID [2022-04-08 13:27:29,240 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {9566#true} {9566#true} #94#return; {9566#true} is VALID [2022-04-08 13:27:29,240 INFO L290 TraceCheckUtils]: 2: Hoare triple {9566#true} assume true; {9566#true} is VALID [2022-04-08 13:27:29,240 INFO L290 TraceCheckUtils]: 1: Hoare triple {9566#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {9566#true} is VALID [2022-04-08 13:27:29,240 INFO L272 TraceCheckUtils]: 0: Hoare triple {9566#true} call ULTIMATE.init(); {9566#true} is VALID [2022-04-08 13:27:29,240 INFO L134 CoverageAnalysis]: Checked inductivity of 483 backedges. 69 proven. 23 refuted. 0 times theorem prover too weak. 391 trivial. 0 not checked. [2022-04-08 13:27:29,240 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-08 13:27:29,241 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [416550877] [2022-04-08 13:27:29,241 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-08 13:27:29,241 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [103034097] [2022-04-08 13:27:29,241 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [103034097] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-08 13:27:29,241 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-08 13:27:29,241 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [9, 8] total 12 [2022-04-08 13:27:29,241 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-08 13:27:29,241 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [1365139620] [2022-04-08 13:27:29,241 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [1365139620] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:27:29,241 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:27:29,241 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [9] imperfect sequences [] total 9 [2022-04-08 13:27:29,241 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1931520613] [2022-04-08 13:27:29,241 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-08 13:27:29,242 INFO L78 Accepts]: Start accepts. Automaton has has 9 states, 9 states have (on average 2.7777777777777777) internal successors, (25), 8 states have internal predecessors, (25), 4 states have call successors, (13), 2 states have call predecessors, (13), 2 states have return successors, (12), 4 states have call predecessors, (12), 4 states have call successors, (12) Word has length 103 [2022-04-08 13:27:29,242 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-08 13:27:29,242 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 9 states, 9 states have (on average 2.7777777777777777) internal successors, (25), 8 states have internal predecessors, (25), 4 states have call successors, (13), 2 states have call predecessors, (13), 2 states have return successors, (12), 4 states have call predecessors, (12), 4 states have call successors, (12) [2022-04-08 13:27:29,279 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 50 edges. 50 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:27:29,279 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 9 states [2022-04-08 13:27:29,279 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-08 13:27:29,279 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 9 interpolants. [2022-04-08 13:27:29,279 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=32, Invalid=100, Unknown=0, NotChecked=0, Total=132 [2022-04-08 13:27:29,279 INFO L87 Difference]: Start difference. First operand 154 states and 175 transitions. Second operand has 9 states, 9 states have (on average 2.7777777777777777) internal successors, (25), 8 states have internal predecessors, (25), 4 states have call successors, (13), 2 states have call predecessors, (13), 2 states have return successors, (12), 4 states have call predecessors, (12), 4 states have call successors, (12) [2022-04-08 13:27:29,690 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:27:29,690 INFO L93 Difference]: Finished difference Result 164 states and 183 transitions. [2022-04-08 13:27:29,690 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 8 states. [2022-04-08 13:27:29,691 INFO L78 Accepts]: Start accepts. Automaton has has 9 states, 9 states have (on average 2.7777777777777777) internal successors, (25), 8 states have internal predecessors, (25), 4 states have call successors, (13), 2 states have call predecessors, (13), 2 states have return successors, (12), 4 states have call predecessors, (12), 4 states have call successors, (12) Word has length 103 [2022-04-08 13:27:29,691 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-08 13:27:29,691 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 9 states, 9 states have (on average 2.7777777777777777) internal successors, (25), 8 states have internal predecessors, (25), 4 states have call successors, (13), 2 states have call predecessors, (13), 2 states have return successors, (12), 4 states have call predecessors, (12), 4 states have call successors, (12) [2022-04-08 13:27:29,691 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 8 states to 8 states and 57 transitions. [2022-04-08 13:27:29,692 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 9 states, 9 states have (on average 2.7777777777777777) internal successors, (25), 8 states have internal predecessors, (25), 4 states have call successors, (13), 2 states have call predecessors, (13), 2 states have return successors, (12), 4 states have call predecessors, (12), 4 states have call successors, (12) [2022-04-08 13:27:29,692 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 8 states to 8 states and 57 transitions. [2022-04-08 13:27:29,692 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 8 states and 57 transitions. [2022-04-08 13:27:29,746 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 57 edges. 57 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:27:29,748 INFO L225 Difference]: With dead ends: 164 [2022-04-08 13:27:29,748 INFO L226 Difference]: Without dead ends: 162 [2022-04-08 13:27:29,748 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 207 GetRequests, 193 SyntacticMatches, 2 SemanticMatches, 12 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 27 ImplicationChecksByTransitivity, 0.1s TimeCoverageRelationStatistics Valid=45, Invalid=137, Unknown=0, NotChecked=0, Total=182 [2022-04-08 13:27:29,749 INFO L913 BasicCegarLoop]: 29 mSDtfsCounter, 20 mSDsluCounter, 73 mSDsCounter, 0 mSdLazyCounter, 127 mSolverCounterSat, 17 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.1s Time, 0 mProtectedPredicate, 0 mProtectedAction, 24 SdHoareTripleChecker+Valid, 102 SdHoareTripleChecker+Invalid, 144 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 17 IncrementalHoareTripleChecker+Valid, 127 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.1s IncrementalHoareTripleChecker+Time [2022-04-08 13:27:29,749 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [24 Valid, 102 Invalid, 144 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [17 Valid, 127 Invalid, 0 Unknown, 0 Unchecked, 0.1s Time] [2022-04-08 13:27:29,749 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 162 states. [2022-04-08 13:27:29,837 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 162 to 162. [2022-04-08 13:27:29,837 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-08 13:27:29,837 INFO L82 GeneralOperation]: Start isEquivalent. First operand 162 states. Second operand has 162 states, 102 states have (on average 1.0980392156862746) internal successors, (112), 106 states have internal predecessors, (112), 36 states have call successors, (36), 24 states have call predecessors, (36), 23 states have return successors, (33), 31 states have call predecessors, (33), 33 states have call successors, (33) [2022-04-08 13:27:29,838 INFO L74 IsIncluded]: Start isIncluded. First operand 162 states. Second operand has 162 states, 102 states have (on average 1.0980392156862746) internal successors, (112), 106 states have internal predecessors, (112), 36 states have call successors, (36), 24 states have call predecessors, (36), 23 states have return successors, (33), 31 states have call predecessors, (33), 33 states have call successors, (33) [2022-04-08 13:27:29,838 INFO L87 Difference]: Start difference. First operand 162 states. Second operand has 162 states, 102 states have (on average 1.0980392156862746) internal successors, (112), 106 states have internal predecessors, (112), 36 states have call successors, (36), 24 states have call predecessors, (36), 23 states have return successors, (33), 31 states have call predecessors, (33), 33 states have call successors, (33) [2022-04-08 13:27:29,840 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:27:29,840 INFO L93 Difference]: Finished difference Result 162 states and 181 transitions. [2022-04-08 13:27:29,840 INFO L276 IsEmpty]: Start isEmpty. Operand 162 states and 181 transitions. [2022-04-08 13:27:29,841 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:27:29,841 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:27:29,841 INFO L74 IsIncluded]: Start isIncluded. First operand has 162 states, 102 states have (on average 1.0980392156862746) internal successors, (112), 106 states have internal predecessors, (112), 36 states have call successors, (36), 24 states have call predecessors, (36), 23 states have return successors, (33), 31 states have call predecessors, (33), 33 states have call successors, (33) Second operand 162 states. [2022-04-08 13:27:29,841 INFO L87 Difference]: Start difference. First operand has 162 states, 102 states have (on average 1.0980392156862746) internal successors, (112), 106 states have internal predecessors, (112), 36 states have call successors, (36), 24 states have call predecessors, (36), 23 states have return successors, (33), 31 states have call predecessors, (33), 33 states have call successors, (33) Second operand 162 states. [2022-04-08 13:27:29,844 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:27:29,844 INFO L93 Difference]: Finished difference Result 162 states and 181 transitions. [2022-04-08 13:27:29,844 INFO L276 IsEmpty]: Start isEmpty. Operand 162 states and 181 transitions. [2022-04-08 13:27:29,844 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:27:29,844 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:27:29,844 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-08 13:27:29,844 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-08 13:27:29,845 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 162 states, 102 states have (on average 1.0980392156862746) internal successors, (112), 106 states have internal predecessors, (112), 36 states have call successors, (36), 24 states have call predecessors, (36), 23 states have return successors, (33), 31 states have call predecessors, (33), 33 states have call successors, (33) [2022-04-08 13:27:29,847 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 162 states to 162 states and 181 transitions. [2022-04-08 13:27:29,847 INFO L78 Accepts]: Start accepts. Automaton has 162 states and 181 transitions. Word has length 103 [2022-04-08 13:27:29,847 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-08 13:27:29,847 INFO L478 AbstractCegarLoop]: Abstraction has 162 states and 181 transitions. [2022-04-08 13:27:29,848 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 9 states, 9 states have (on average 2.7777777777777777) internal successors, (25), 8 states have internal predecessors, (25), 4 states have call successors, (13), 2 states have call predecessors, (13), 2 states have return successors, (12), 4 states have call predecessors, (12), 4 states have call successors, (12) [2022-04-08 13:27:29,848 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 162 states and 181 transitions. [2022-04-08 13:27:30,052 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 181 edges. 181 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:27:30,052 INFO L276 IsEmpty]: Start isEmpty. Operand 162 states and 181 transitions. [2022-04-08 13:27:30,053 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 106 [2022-04-08 13:27:30,053 INFO L491 BasicCegarLoop]: Found error trace [2022-04-08 13:27:30,053 INFO L499 BasicCegarLoop]: trace histogram [16, 15, 15, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-08 13:27:30,075 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (11)] Forceful destruction successful, exit code 0 [2022-04-08 13:27:30,253 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 11 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable12 [2022-04-08 13:27:30,253 INFO L403 AbstractCegarLoop]: === Iteration 14 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-08 13:27:30,254 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-08 13:27:30,254 INFO L85 PathProgramCache]: Analyzing trace with hash 1306280540, now seen corresponding path program 3 times [2022-04-08 13:27:30,254 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-08 13:27:30,254 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [508389125] [2022-04-08 13:27:34,326 INFO L97 AcceleratorQvasr]: Qvasr could not accelerate loop because java.lang.UnsupportedOperationException: Cannot deal with arrays. [2022-04-08 13:27:34,327 INFO L274 tedInterpolationCore]: Could not compute an accelerate. [2022-04-08 13:27:34,327 INFO L85 PathProgramCache]: Analyzing trace with hash 1306280540, now seen corresponding path program 4 times [2022-04-08 13:27:34,327 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-08 13:27:34,327 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [416322426] [2022-04-08 13:27:34,327 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-08 13:27:34,327 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-08 13:27:34,335 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-08 13:27:34,335 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1858284248] [2022-04-08 13:27:34,335 INFO L93 rtionOrderModulation]: Changing assertion order to TERMS_WITH_SMALL_CONSTANTS_FIRST [2022-04-08 13:27:34,335 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:27:34,335 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-08 13:27:34,336 INFO L229 MonitoredProcess]: Starting monitored process 12 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-08 13:27:34,337 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (12)] Waiting until timeout for monitored process [2022-04-08 13:27:34,380 INFO L228 tOrderPrioritization]: Assert order TERMS_WITH_SMALL_CONSTANTS_FIRST issued 0 check-sat command(s) [2022-04-08 13:27:34,380 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-08 13:27:34,381 INFO L263 TraceCheckSpWp]: Trace formula consists of 214 conjuncts, 39 conjunts are in the unsatisfiable core [2022-04-08 13:27:34,398 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:27:34,399 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-08 13:27:34,936 INFO L272 TraceCheckUtils]: 0: Hoare triple {11175#true} call ULTIMATE.init(); {11175#true} is VALID [2022-04-08 13:27:34,936 INFO L290 TraceCheckUtils]: 1: Hoare triple {11175#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {11175#true} is VALID [2022-04-08 13:27:34,936 INFO L290 TraceCheckUtils]: 2: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:34,936 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {11175#true} {11175#true} #94#return; {11175#true} is VALID [2022-04-08 13:27:34,936 INFO L272 TraceCheckUtils]: 4: Hoare triple {11175#true} call #t~ret5 := main(); {11175#true} is VALID [2022-04-08 13:27:34,936 INFO L290 TraceCheckUtils]: 5: Hoare triple {11175#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {11175#true} is VALID [2022-04-08 13:27:34,936 INFO L272 TraceCheckUtils]: 6: Hoare triple {11175#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:34,936 INFO L290 TraceCheckUtils]: 7: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:34,936 INFO L290 TraceCheckUtils]: 8: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:34,937 INFO L290 TraceCheckUtils]: 9: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:34,937 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {11175#true} {11175#true} #78#return; {11175#true} is VALID [2022-04-08 13:27:34,937 INFO L290 TraceCheckUtils]: 11: Hoare triple {11175#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {11213#(and (= main_~A~0 main_~r~0) (= main_~d~0 1) (= main_~q~0 0) (= main_~p~0 1))} is VALID [2022-04-08 13:27:34,937 INFO L290 TraceCheckUtils]: 12: Hoare triple {11213#(and (= main_~A~0 main_~r~0) (= main_~d~0 1) (= main_~q~0 0) (= main_~p~0 1))} assume !false; {11213#(and (= main_~A~0 main_~r~0) (= main_~d~0 1) (= main_~q~0 0) (= main_~p~0 1))} is VALID [2022-04-08 13:27:34,937 INFO L272 TraceCheckUtils]: 13: Hoare triple {11213#(and (= main_~A~0 main_~r~0) (= main_~d~0 1) (= main_~q~0 0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:34,937 INFO L290 TraceCheckUtils]: 14: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:34,938 INFO L290 TraceCheckUtils]: 15: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:34,938 INFO L290 TraceCheckUtils]: 16: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:34,938 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {11175#true} {11213#(and (= main_~A~0 main_~r~0) (= main_~d~0 1) (= main_~q~0 0) (= main_~p~0 1))} #80#return; {11213#(and (= main_~A~0 main_~r~0) (= main_~d~0 1) (= main_~q~0 0) (= main_~p~0 1))} is VALID [2022-04-08 13:27:34,938 INFO L272 TraceCheckUtils]: 18: Hoare triple {11213#(and (= main_~A~0 main_~r~0) (= main_~d~0 1) (= main_~q~0 0) (= main_~p~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:34,938 INFO L290 TraceCheckUtils]: 19: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:34,938 INFO L290 TraceCheckUtils]: 20: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:34,938 INFO L290 TraceCheckUtils]: 21: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:34,939 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {11175#true} {11213#(and (= main_~A~0 main_~r~0) (= main_~d~0 1) (= main_~q~0 0) (= main_~p~0 1))} #82#return; {11213#(and (= main_~A~0 main_~r~0) (= main_~d~0 1) (= main_~q~0 0) (= main_~p~0 1))} is VALID [2022-04-08 13:27:34,939 INFO L272 TraceCheckUtils]: 23: Hoare triple {11213#(and (= main_~A~0 main_~r~0) (= main_~d~0 1) (= main_~q~0 0) (= main_~p~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:34,939 INFO L290 TraceCheckUtils]: 24: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:34,939 INFO L290 TraceCheckUtils]: 25: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:34,939 INFO L290 TraceCheckUtils]: 26: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:34,947 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {11175#true} {11213#(and (= main_~A~0 main_~r~0) (= main_~d~0 1) (= main_~q~0 0) (= main_~p~0 1))} #84#return; {11213#(and (= main_~A~0 main_~r~0) (= main_~d~0 1) (= main_~q~0 0) (= main_~p~0 1))} is VALID [2022-04-08 13:27:34,948 INFO L290 TraceCheckUtils]: 28: Hoare triple {11213#(and (= main_~A~0 main_~r~0) (= main_~d~0 1) (= main_~q~0 0) (= main_~p~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {11265#(and (= main_~A~0 main_~r~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~q~0 0))} is VALID [2022-04-08 13:27:34,948 INFO L290 TraceCheckUtils]: 29: Hoare triple {11265#(and (= main_~A~0 main_~r~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~q~0 0))} assume !false; {11265#(and (= main_~A~0 main_~r~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~q~0 0))} is VALID [2022-04-08 13:27:34,948 INFO L272 TraceCheckUtils]: 30: Hoare triple {11265#(and (= main_~A~0 main_~r~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~q~0 0))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:34,948 INFO L290 TraceCheckUtils]: 31: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:34,948 INFO L290 TraceCheckUtils]: 32: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:34,948 INFO L290 TraceCheckUtils]: 33: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:34,949 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {11175#true} {11265#(and (= main_~A~0 main_~r~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~q~0 0))} #80#return; {11265#(and (= main_~A~0 main_~r~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~q~0 0))} is VALID [2022-04-08 13:27:34,949 INFO L272 TraceCheckUtils]: 35: Hoare triple {11265#(and (= main_~A~0 main_~r~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~q~0 0))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:34,949 INFO L290 TraceCheckUtils]: 36: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:34,949 INFO L290 TraceCheckUtils]: 37: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:34,949 INFO L290 TraceCheckUtils]: 38: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:34,950 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {11175#true} {11265#(and (= main_~A~0 main_~r~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~q~0 0))} #82#return; {11265#(and (= main_~A~0 main_~r~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~q~0 0))} is VALID [2022-04-08 13:27:34,950 INFO L272 TraceCheckUtils]: 40: Hoare triple {11265#(and (= main_~A~0 main_~r~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~q~0 0))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:34,950 INFO L290 TraceCheckUtils]: 41: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:34,950 INFO L290 TraceCheckUtils]: 42: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:34,950 INFO L290 TraceCheckUtils]: 43: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:34,951 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {11175#true} {11265#(and (= main_~A~0 main_~r~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~q~0 0))} #84#return; {11265#(and (= main_~A~0 main_~r~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~q~0 0))} is VALID [2022-04-08 13:27:34,951 INFO L290 TraceCheckUtils]: 45: Hoare triple {11265#(and (= main_~A~0 main_~r~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~q~0 0))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} is VALID [2022-04-08 13:27:34,951 INFO L290 TraceCheckUtils]: 46: Hoare triple {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} assume !false; {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} is VALID [2022-04-08 13:27:34,952 INFO L272 TraceCheckUtils]: 47: Hoare triple {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:34,952 INFO L290 TraceCheckUtils]: 48: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:34,952 INFO L290 TraceCheckUtils]: 49: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:34,952 INFO L290 TraceCheckUtils]: 50: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:34,952 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {11175#true} {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} #80#return; {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} is VALID [2022-04-08 13:27:34,952 INFO L272 TraceCheckUtils]: 52: Hoare triple {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:34,952 INFO L290 TraceCheckUtils]: 53: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:34,952 INFO L290 TraceCheckUtils]: 54: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:34,953 INFO L290 TraceCheckUtils]: 55: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:34,953 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {11175#true} {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} #82#return; {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} is VALID [2022-04-08 13:27:34,953 INFO L272 TraceCheckUtils]: 57: Hoare triple {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:34,953 INFO L290 TraceCheckUtils]: 58: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:34,953 INFO L290 TraceCheckUtils]: 59: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:34,953 INFO L290 TraceCheckUtils]: 60: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:34,954 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {11175#true} {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} #84#return; {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} is VALID [2022-04-08 13:27:34,954 INFO L290 TraceCheckUtils]: 62: Hoare triple {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} assume !(~r~0 >= ~d~0); {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} is VALID [2022-04-08 13:27:34,954 INFO L290 TraceCheckUtils]: 63: Hoare triple {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} assume !false; {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} is VALID [2022-04-08 13:27:34,954 INFO L272 TraceCheckUtils]: 64: Hoare triple {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:34,954 INFO L290 TraceCheckUtils]: 65: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:34,954 INFO L290 TraceCheckUtils]: 66: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:34,955 INFO L290 TraceCheckUtils]: 67: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:34,955 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {11175#true} {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} #86#return; {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} is VALID [2022-04-08 13:27:34,955 INFO L272 TraceCheckUtils]: 69: Hoare triple {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:34,955 INFO L290 TraceCheckUtils]: 70: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:34,955 INFO L290 TraceCheckUtils]: 71: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:34,955 INFO L290 TraceCheckUtils]: 72: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:34,956 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {11175#true} {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} #88#return; {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} is VALID [2022-04-08 13:27:34,956 INFO L290 TraceCheckUtils]: 74: Hoare triple {11317#(and (= main_~A~0 main_~r~0) (= main_~d~0 4) (= main_~q~0 0) (= main_~p~0 4))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {11265#(and (= main_~A~0 main_~r~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~q~0 0))} is VALID [2022-04-08 13:27:34,957 INFO L290 TraceCheckUtils]: 75: Hoare triple {11265#(and (= main_~A~0 main_~r~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~q~0 0))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {11408#(and (= main_~q~0 main_~p~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} is VALID [2022-04-08 13:27:34,957 INFO L290 TraceCheckUtils]: 76: Hoare triple {11408#(and (= main_~q~0 main_~p~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} assume !false; {11408#(and (= main_~q~0 main_~p~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} is VALID [2022-04-08 13:27:34,957 INFO L272 TraceCheckUtils]: 77: Hoare triple {11408#(and (= main_~q~0 main_~p~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:34,957 INFO L290 TraceCheckUtils]: 78: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:34,957 INFO L290 TraceCheckUtils]: 79: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:34,957 INFO L290 TraceCheckUtils]: 80: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:34,958 INFO L284 TraceCheckUtils]: 81: Hoare quadruple {11175#true} {11408#(and (= main_~q~0 main_~p~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} #86#return; {11408#(and (= main_~q~0 main_~p~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} is VALID [2022-04-08 13:27:34,958 INFO L272 TraceCheckUtils]: 82: Hoare triple {11408#(and (= main_~q~0 main_~p~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:34,958 INFO L290 TraceCheckUtils]: 83: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:34,958 INFO L290 TraceCheckUtils]: 84: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:34,958 INFO L290 TraceCheckUtils]: 85: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:34,958 INFO L284 TraceCheckUtils]: 86: Hoare quadruple {11175#true} {11408#(and (= main_~q~0 main_~p~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} #88#return; {11408#(and (= main_~q~0 main_~p~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} is VALID [2022-04-08 13:27:34,959 INFO L290 TraceCheckUtils]: 87: Hoare triple {11408#(and (= main_~q~0 main_~p~0) (= main_~p~0 2) (= main_~d~0 2) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {11445#(and (= main_~q~0 2) (= (div (+ main_~A~0 (* (- 1) main_~r~0)) 2) main_~d~0) (= (+ main_~A~0 (* (- 1) main_~r~0)) 2) (= main_~p~0 1))} is VALID [2022-04-08 13:27:34,960 INFO L290 TraceCheckUtils]: 88: Hoare triple {11445#(and (= main_~q~0 2) (= (div (+ main_~A~0 (* (- 1) main_~r~0)) 2) main_~d~0) (= (+ main_~A~0 (* (- 1) main_~r~0)) 2) (= main_~p~0 1))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {11449#(and (= (+ main_~p~0 2) main_~q~0) (= (div (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) main_~d~0) (= (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) (= main_~p~0 1))} is VALID [2022-04-08 13:27:34,960 INFO L290 TraceCheckUtils]: 89: Hoare triple {11449#(and (= (+ main_~p~0 2) main_~q~0) (= (div (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) main_~d~0) (= (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) (= main_~p~0 1))} assume !false; {11449#(and (= (+ main_~p~0 2) main_~q~0) (= (div (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) main_~d~0) (= (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) (= main_~p~0 1))} is VALID [2022-04-08 13:27:34,960 INFO L272 TraceCheckUtils]: 90: Hoare triple {11449#(and (= (+ main_~p~0 2) main_~q~0) (= (div (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) main_~d~0) (= (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) (= main_~p~0 1))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:34,960 INFO L290 TraceCheckUtils]: 91: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:34,960 INFO L290 TraceCheckUtils]: 92: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:34,960 INFO L290 TraceCheckUtils]: 93: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:34,961 INFO L284 TraceCheckUtils]: 94: Hoare quadruple {11175#true} {11449#(and (= (+ main_~p~0 2) main_~q~0) (= (div (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) main_~d~0) (= (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) (= main_~p~0 1))} #86#return; {11449#(and (= (+ main_~p~0 2) main_~q~0) (= (div (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) main_~d~0) (= (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) (= main_~p~0 1))} is VALID [2022-04-08 13:27:34,961 INFO L272 TraceCheckUtils]: 95: Hoare triple {11449#(and (= (+ main_~p~0 2) main_~q~0) (= (div (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) main_~d~0) (= (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) (= main_~p~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:34,961 INFO L290 TraceCheckUtils]: 96: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:34,961 INFO L290 TraceCheckUtils]: 97: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:34,961 INFO L290 TraceCheckUtils]: 98: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:34,962 INFO L284 TraceCheckUtils]: 99: Hoare quadruple {11175#true} {11449#(and (= (+ main_~p~0 2) main_~q~0) (= (div (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) main_~d~0) (= (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) (= main_~p~0 1))} #88#return; {11449#(and (= (+ main_~p~0 2) main_~q~0) (= (div (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) main_~d~0) (= (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) (= main_~p~0 1))} is VALID [2022-04-08 13:27:34,962 INFO L290 TraceCheckUtils]: 100: Hoare triple {11449#(and (= (+ main_~p~0 2) main_~q~0) (= (div (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) main_~d~0) (= (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) (= main_~p~0 1))} assume !(1 != ~p~0); {11486#(and (= (div (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) main_~d~0) (= (+ (- 2) main_~q~0) 1) (= (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2))} is VALID [2022-04-08 13:27:34,963 INFO L272 TraceCheckUtils]: 101: Hoare triple {11486#(and (= (div (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2) main_~d~0) (= (+ (- 2) main_~q~0) 1) (= (+ (* (- 1) main_~d~0) main_~A~0 (* (- 1) main_~r~0)) 2))} call __VERIFIER_assert((if ~A~0 == ~d~0 * ~q~0 + ~r~0 then 1 else 0)); {11490#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:27:34,963 INFO L290 TraceCheckUtils]: 102: Hoare triple {11490#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {11494#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:27:34,963 INFO L290 TraceCheckUtils]: 103: Hoare triple {11494#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {11176#false} is VALID [2022-04-08 13:27:34,963 INFO L290 TraceCheckUtils]: 104: Hoare triple {11176#false} assume !false; {11176#false} is VALID [2022-04-08 13:27:34,964 INFO L134 CoverageAnalysis]: Checked inductivity of 478 backedges. 30 proven. 28 refuted. 0 times theorem prover too weak. 420 trivial. 0 not checked. [2022-04-08 13:27:34,964 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-08 13:27:58,302 INFO L290 TraceCheckUtils]: 104: Hoare triple {11176#false} assume !false; {11176#false} is VALID [2022-04-08 13:27:58,303 INFO L290 TraceCheckUtils]: 103: Hoare triple {11494#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {11176#false} is VALID [2022-04-08 13:27:58,303 INFO L290 TraceCheckUtils]: 102: Hoare triple {11490#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {11494#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:27:58,304 INFO L272 TraceCheckUtils]: 101: Hoare triple {11510#(= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0)} call __VERIFIER_assert((if ~A~0 == ~d~0 * ~q~0 + ~r~0 then 1 else 0)); {11490#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:27:58,304 INFO L290 TraceCheckUtils]: 100: Hoare triple {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} assume !(1 != ~p~0); {11510#(= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:27:58,305 INFO L284 TraceCheckUtils]: 99: Hoare quadruple {11175#true} {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} #88#return; {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} is VALID [2022-04-08 13:27:58,305 INFO L290 TraceCheckUtils]: 98: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:58,305 INFO L290 TraceCheckUtils]: 97: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:58,305 INFO L290 TraceCheckUtils]: 96: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:58,305 INFO L272 TraceCheckUtils]: 95: Hoare triple {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:58,305 INFO L284 TraceCheckUtils]: 94: Hoare quadruple {11175#true} {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} #86#return; {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} is VALID [2022-04-08 13:27:58,305 INFO L290 TraceCheckUtils]: 93: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:58,306 INFO L290 TraceCheckUtils]: 92: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:58,306 INFO L290 TraceCheckUtils]: 91: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:58,306 INFO L272 TraceCheckUtils]: 90: Hoare triple {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:58,306 INFO L290 TraceCheckUtils]: 89: Hoare triple {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} assume !false; {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} is VALID [2022-04-08 13:27:58,308 INFO L290 TraceCheckUtils]: 88: Hoare triple {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} is VALID [2022-04-08 13:27:58,312 INFO L290 TraceCheckUtils]: 87: Hoare triple {11554#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* main_~q~0 (div main_~d~0 2)) main_~r~0)) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (= (+ (* (+ (div main_~d~0 2) 1) main_~q~0) main_~r~0) main_~A~0))))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} is VALID [2022-04-08 13:27:58,312 INFO L284 TraceCheckUtils]: 86: Hoare quadruple {11175#true} {11554#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* main_~q~0 (div main_~d~0 2)) main_~r~0)) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (= (+ (* (+ (div main_~d~0 2) 1) main_~q~0) main_~r~0) main_~A~0))))} #88#return; {11554#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* main_~q~0 (div main_~d~0 2)) main_~r~0)) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (= (+ (* (+ (div main_~d~0 2) 1) main_~q~0) main_~r~0) main_~A~0))))} is VALID [2022-04-08 13:27:58,312 INFO L290 TraceCheckUtils]: 85: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:58,312 INFO L290 TraceCheckUtils]: 84: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:58,312 INFO L290 TraceCheckUtils]: 83: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:58,313 INFO L272 TraceCheckUtils]: 82: Hoare triple {11554#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* main_~q~0 (div main_~d~0 2)) main_~r~0)) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (= (+ (* (+ (div main_~d~0 2) 1) main_~q~0) main_~r~0) main_~A~0))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:58,313 INFO L284 TraceCheckUtils]: 81: Hoare quadruple {11175#true} {11554#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* main_~q~0 (div main_~d~0 2)) main_~r~0)) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (= (+ (* (+ (div main_~d~0 2) 1) main_~q~0) main_~r~0) main_~A~0))))} #86#return; {11554#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* main_~q~0 (div main_~d~0 2)) main_~r~0)) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (= (+ (* (+ (div main_~d~0 2) 1) main_~q~0) main_~r~0) main_~A~0))))} is VALID [2022-04-08 13:27:58,313 INFO L290 TraceCheckUtils]: 80: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:58,313 INFO L290 TraceCheckUtils]: 79: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:58,313 INFO L290 TraceCheckUtils]: 78: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:58,313 INFO L272 TraceCheckUtils]: 77: Hoare triple {11554#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* main_~q~0 (div main_~d~0 2)) main_~r~0)) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (= (+ (* (+ (div main_~d~0 2) 1) main_~q~0) main_~r~0) main_~A~0))))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:58,314 INFO L290 TraceCheckUtils]: 76: Hoare triple {11554#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* main_~q~0 (div main_~d~0 2)) main_~r~0)) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (= (+ (* (+ (div main_~d~0 2) 1) main_~q~0) main_~r~0) main_~A~0))))} assume !false; {11554#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* main_~q~0 (div main_~d~0 2)) main_~r~0)) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (= (+ (* (+ (div main_~d~0 2) 1) main_~q~0) main_~r~0) main_~A~0))))} is VALID [2022-04-08 13:27:58,455 INFO L290 TraceCheckUtils]: 75: Hoare triple {11591#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0) (+ (div main_~d~0 2) 1)) main_~r~0)) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) (div main_~d~0 2)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)))))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {11554#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* main_~q~0 (div main_~d~0 2)) main_~r~0)) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (= (+ (* (+ (div main_~d~0 2) 1) main_~q~0) main_~r~0) main_~A~0))))} is VALID [2022-04-08 13:27:58,484 INFO L290 TraceCheckUtils]: 74: Hoare triple {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {11591#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0) (+ (div main_~d~0 2) 1)) main_~r~0)) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) (div main_~d~0 2)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)))))} is VALID [2022-04-08 13:27:58,485 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {11175#true} {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} #88#return; {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} is VALID [2022-04-08 13:27:58,485 INFO L290 TraceCheckUtils]: 72: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:58,485 INFO L290 TraceCheckUtils]: 71: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:58,485 INFO L290 TraceCheckUtils]: 70: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:58,485 INFO L272 TraceCheckUtils]: 69: Hoare triple {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:58,486 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {11175#true} {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} #86#return; {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} is VALID [2022-04-08 13:27:58,486 INFO L290 TraceCheckUtils]: 67: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:58,486 INFO L290 TraceCheckUtils]: 66: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:58,486 INFO L290 TraceCheckUtils]: 65: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:58,486 INFO L272 TraceCheckUtils]: 64: Hoare triple {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:58,487 INFO L290 TraceCheckUtils]: 63: Hoare triple {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} assume !false; {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} is VALID [2022-04-08 13:27:58,489 INFO L290 TraceCheckUtils]: 62: Hoare triple {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} assume !(~r~0 >= ~d~0); {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} is VALID [2022-04-08 13:27:58,489 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {11175#true} {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} #84#return; {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} is VALID [2022-04-08 13:27:58,489 INFO L290 TraceCheckUtils]: 60: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:58,489 INFO L290 TraceCheckUtils]: 59: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:58,489 INFO L290 TraceCheckUtils]: 58: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:58,489 INFO L272 TraceCheckUtils]: 57: Hoare triple {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:58,490 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {11175#true} {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} #82#return; {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} is VALID [2022-04-08 13:27:58,490 INFO L290 TraceCheckUtils]: 55: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:58,490 INFO L290 TraceCheckUtils]: 54: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:58,490 INFO L290 TraceCheckUtils]: 53: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:58,490 INFO L272 TraceCheckUtils]: 52: Hoare triple {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:58,491 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {11175#true} {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} #80#return; {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} is VALID [2022-04-08 13:27:58,491 INFO L290 TraceCheckUtils]: 50: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:58,491 INFO L290 TraceCheckUtils]: 49: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:58,491 INFO L290 TraceCheckUtils]: 48: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:58,491 INFO L272 TraceCheckUtils]: 47: Hoare triple {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:58,492 INFO L290 TraceCheckUtils]: 46: Hoare triple {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} assume !false; {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} is VALID [2022-04-08 13:27:58,507 INFO L290 TraceCheckUtils]: 45: Hoare triple {11591#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0) (+ (div main_~d~0 2) 1)) main_~r~0)) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) (div main_~d~0 2)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)))))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {11595#(or (and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (= (+ (* (+ (div (div main_~d~0 2) 2) 1) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (= main_~A~0 (+ main_~r~0 (* (div (div main_~d~0 2) 2) (+ main_~q~0 (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))))) (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (= (+ (- 1) (* (div (+ (div main_~d~0 2) 1) 2) (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ (div (+ (div main_~d~0 2) 1) 2) 1) (+ main_~q~0 (div main_~p~0 2)))) main_~A~0) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0))) (< (div main_~p~0 2) 2) (<= 4 (div main_~p~0 2)))} is VALID [2022-04-08 13:27:58,508 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {11175#true} {11591#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0) (+ (div main_~d~0 2) 1)) main_~r~0)) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) (div main_~d~0 2)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)))))} #84#return; {11591#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0) (+ (div main_~d~0 2) 1)) main_~r~0)) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) (div main_~d~0 2)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)))))} is VALID [2022-04-08 13:27:58,508 INFO L290 TraceCheckUtils]: 43: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:58,508 INFO L290 TraceCheckUtils]: 42: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:58,508 INFO L290 TraceCheckUtils]: 41: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:58,508 INFO L272 TraceCheckUtils]: 40: Hoare triple {11591#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0) (+ (div main_~d~0 2) 1)) main_~r~0)) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) (div main_~d~0 2)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:58,508 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {11175#true} {11591#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0) (+ (div main_~d~0 2) 1)) main_~r~0)) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) (div main_~d~0 2)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)))))} #82#return; {11591#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0) (+ (div main_~d~0 2) 1)) main_~r~0)) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) (div main_~d~0 2)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)))))} is VALID [2022-04-08 13:27:58,508 INFO L290 TraceCheckUtils]: 38: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:58,508 INFO L290 TraceCheckUtils]: 37: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:58,509 INFO L290 TraceCheckUtils]: 36: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:58,509 INFO L272 TraceCheckUtils]: 35: Hoare triple {11591#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0) (+ (div main_~d~0 2) 1)) main_~r~0)) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) (div main_~d~0 2)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)))))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:58,509 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {11175#true} {11591#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0) (+ (div main_~d~0 2) 1)) main_~r~0)) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) (div main_~d~0 2)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)))))} #80#return; {11591#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0) (+ (div main_~d~0 2) 1)) main_~r~0)) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) (div main_~d~0 2)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)))))} is VALID [2022-04-08 13:27:58,509 INFO L290 TraceCheckUtils]: 33: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:58,509 INFO L290 TraceCheckUtils]: 32: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:58,509 INFO L290 TraceCheckUtils]: 31: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:58,509 INFO L272 TraceCheckUtils]: 30: Hoare triple {11591#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0) (+ (div main_~d~0 2) 1)) main_~r~0)) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) (div main_~d~0 2)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)))))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:58,510 INFO L290 TraceCheckUtils]: 29: Hoare triple {11591#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0) (+ (div main_~d~0 2) 1)) main_~r~0)) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) (div main_~d~0 2)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)))))} assume !false; {11591#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0) (+ (div main_~d~0 2) 1)) main_~r~0)) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) (div main_~d~0 2)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)))))} is VALID [2022-04-08 13:27:58,526 INFO L290 TraceCheckUtils]: 28: Hoare triple {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {11591#(or (not (= (div main_~p~0 2) 1)) (and (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0) (+ (div main_~d~0 2) 1)) main_~r~0)) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) (div main_~d~0 2)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)))))} is VALID [2022-04-08 13:27:58,526 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {11175#true} {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} #84#return; {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} is VALID [2022-04-08 13:27:58,527 INFO L290 TraceCheckUtils]: 26: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:58,527 INFO L290 TraceCheckUtils]: 25: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:58,527 INFO L290 TraceCheckUtils]: 24: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:58,527 INFO L272 TraceCheckUtils]: 23: Hoare triple {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:58,527 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {11175#true} {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} #82#return; {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} is VALID [2022-04-08 13:27:58,527 INFO L290 TraceCheckUtils]: 21: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:58,527 INFO L290 TraceCheckUtils]: 20: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:58,527 INFO L290 TraceCheckUtils]: 19: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:58,527 INFO L272 TraceCheckUtils]: 18: Hoare triple {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:58,528 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {11175#true} {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} #80#return; {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} is VALID [2022-04-08 13:27:58,528 INFO L290 TraceCheckUtils]: 16: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:58,528 INFO L290 TraceCheckUtils]: 15: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:58,528 INFO L290 TraceCheckUtils]: 14: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:58,528 INFO L272 TraceCheckUtils]: 13: Hoare triple {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:58,528 INFO L290 TraceCheckUtils]: 12: Hoare triple {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} assume !false; {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} is VALID [2022-04-08 13:27:58,529 INFO L290 TraceCheckUtils]: 11: Hoare triple {11175#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {11514#(or (= (+ (* main_~d~0 main_~q~0) main_~r~0) main_~A~0) (not (= main_~p~0 1)))} is VALID [2022-04-08 13:27:58,529 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {11175#true} {11175#true} #78#return; {11175#true} is VALID [2022-04-08 13:27:58,529 INFO L290 TraceCheckUtils]: 9: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:58,529 INFO L290 TraceCheckUtils]: 8: Hoare triple {11175#true} assume !(0 == ~cond); {11175#true} is VALID [2022-04-08 13:27:58,529 INFO L290 TraceCheckUtils]: 7: Hoare triple {11175#true} ~cond := #in~cond; {11175#true} is VALID [2022-04-08 13:27:58,529 INFO L272 TraceCheckUtils]: 6: Hoare triple {11175#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {11175#true} is VALID [2022-04-08 13:27:58,529 INFO L290 TraceCheckUtils]: 5: Hoare triple {11175#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {11175#true} is VALID [2022-04-08 13:27:58,529 INFO L272 TraceCheckUtils]: 4: Hoare triple {11175#true} call #t~ret5 := main(); {11175#true} is VALID [2022-04-08 13:27:58,529 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {11175#true} {11175#true} #94#return; {11175#true} is VALID [2022-04-08 13:27:58,529 INFO L290 TraceCheckUtils]: 2: Hoare triple {11175#true} assume true; {11175#true} is VALID [2022-04-08 13:27:58,529 INFO L290 TraceCheckUtils]: 1: Hoare triple {11175#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {11175#true} is VALID [2022-04-08 13:27:58,529 INFO L272 TraceCheckUtils]: 0: Hoare triple {11175#true} call ULTIMATE.init(); {11175#true} is VALID [2022-04-08 13:27:58,530 INFO L134 CoverageAnalysis]: Checked inductivity of 478 backedges. 30 proven. 28 refuted. 0 times theorem prover too weak. 420 trivial. 0 not checked. [2022-04-08 13:27:58,530 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-08 13:27:58,530 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [416322426] [2022-04-08 13:27:58,530 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-08 13:27:58,530 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1858284248] [2022-04-08 13:27:58,530 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1858284248] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-08 13:27:58,530 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-08 13:27:58,530 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [11, 9] total 16 [2022-04-08 13:27:58,531 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-08 13:27:58,531 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [508389125] [2022-04-08 13:27:58,531 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [508389125] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:27:58,531 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:27:58,531 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [11] imperfect sequences [] total 11 [2022-04-08 13:27:58,531 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [866319825] [2022-04-08 13:27:58,531 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-08 13:27:58,531 INFO L78 Accepts]: Start accepts. Automaton has has 11 states, 10 states have (on average 2.7) internal successors, (27), 10 states have internal predecessors, (27), 7 states have call successors, (19), 2 states have call predecessors, (19), 1 states have return successors, (17), 6 states have call predecessors, (17), 6 states have call successors, (17) Word has length 105 [2022-04-08 13:27:58,531 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-08 13:27:58,532 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 11 states, 10 states have (on average 2.7) internal successors, (27), 10 states have internal predecessors, (27), 7 states have call successors, (19), 2 states have call predecessors, (19), 1 states have return successors, (17), 6 states have call predecessors, (17), 6 states have call successors, (17) [2022-04-08 13:27:58,583 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 63 edges. 63 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:27:58,583 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 11 states [2022-04-08 13:27:58,583 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-08 13:27:58,583 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 11 interpolants. [2022-04-08 13:27:58,583 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=62, Invalid=178, Unknown=0, NotChecked=0, Total=240 [2022-04-08 13:27:58,584 INFO L87 Difference]: Start difference. First operand 162 states and 181 transitions. Second operand has 11 states, 10 states have (on average 2.7) internal successors, (27), 10 states have internal predecessors, (27), 7 states have call successors, (19), 2 states have call predecessors, (19), 1 states have return successors, (17), 6 states have call predecessors, (17), 6 states have call successors, (17) [2022-04-08 13:27:59,580 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:27:59,581 INFO L93 Difference]: Finished difference Result 171 states and 190 transitions. [2022-04-08 13:27:59,581 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 10 states. [2022-04-08 13:27:59,581 INFO L78 Accepts]: Start accepts. Automaton has has 11 states, 10 states have (on average 2.7) internal successors, (27), 10 states have internal predecessors, (27), 7 states have call successors, (19), 2 states have call predecessors, (19), 1 states have return successors, (17), 6 states have call predecessors, (17), 6 states have call successors, (17) Word has length 105 [2022-04-08 13:27:59,581 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-08 13:27:59,581 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 11 states, 10 states have (on average 2.7) internal successors, (27), 10 states have internal predecessors, (27), 7 states have call successors, (19), 2 states have call predecessors, (19), 1 states have return successors, (17), 6 states have call predecessors, (17), 6 states have call successors, (17) [2022-04-08 13:27:59,582 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 10 states to 10 states and 97 transitions. [2022-04-08 13:27:59,583 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 11 states, 10 states have (on average 2.7) internal successors, (27), 10 states have internal predecessors, (27), 7 states have call successors, (19), 2 states have call predecessors, (19), 1 states have return successors, (17), 6 states have call predecessors, (17), 6 states have call successors, (17) [2022-04-08 13:27:59,584 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 10 states to 10 states and 97 transitions. [2022-04-08 13:27:59,584 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 10 states and 97 transitions. [2022-04-08 13:27:59,663 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 97 edges. 97 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:27:59,665 INFO L225 Difference]: With dead ends: 171 [2022-04-08 13:27:59,665 INFO L226 Difference]: Without dead ends: 143 [2022-04-08 13:27:59,666 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 210 GetRequests, 191 SyntacticMatches, 4 SemanticMatches, 15 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 11 ImplicationChecksByTransitivity, 0.8s TimeCoverageRelationStatistics Valid=66, Invalid=206, Unknown=0, NotChecked=0, Total=272 [2022-04-08 13:27:59,666 INFO L913 BasicCegarLoop]: 56 mSDtfsCounter, 9 mSDsluCounter, 220 mSDsCounter, 0 mSdLazyCounter, 390 mSolverCounterSat, 12 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.4s Time, 0 mProtectedPredicate, 0 mProtectedAction, 11 SdHoareTripleChecker+Valid, 276 SdHoareTripleChecker+Invalid, 402 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 12 IncrementalHoareTripleChecker+Valid, 390 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.4s IncrementalHoareTripleChecker+Time [2022-04-08 13:27:59,666 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [11 Valid, 276 Invalid, 402 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [12 Valid, 390 Invalid, 0 Unknown, 0 Unchecked, 0.4s Time] [2022-04-08 13:27:59,667 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 143 states. [2022-04-08 13:27:59,745 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 143 to 143. [2022-04-08 13:27:59,746 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-08 13:27:59,746 INFO L82 GeneralOperation]: Start isEquivalent. First operand 143 states. Second operand has 143 states, 89 states have (on average 1.101123595505618) internal successors, (98), 92 states have internal predecessors, (98), 33 states have call successors, (33), 21 states have call predecessors, (33), 20 states have return successors, (30), 29 states have call predecessors, (30), 30 states have call successors, (30) [2022-04-08 13:27:59,746 INFO L74 IsIncluded]: Start isIncluded. First operand 143 states. Second operand has 143 states, 89 states have (on average 1.101123595505618) internal successors, (98), 92 states have internal predecessors, (98), 33 states have call successors, (33), 21 states have call predecessors, (33), 20 states have return successors, (30), 29 states have call predecessors, (30), 30 states have call successors, (30) [2022-04-08 13:27:59,746 INFO L87 Difference]: Start difference. First operand 143 states. Second operand has 143 states, 89 states have (on average 1.101123595505618) internal successors, (98), 92 states have internal predecessors, (98), 33 states have call successors, (33), 21 states have call predecessors, (33), 20 states have return successors, (30), 29 states have call predecessors, (30), 30 states have call successors, (30) [2022-04-08 13:27:59,749 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:27:59,749 INFO L93 Difference]: Finished difference Result 143 states and 161 transitions. [2022-04-08 13:27:59,749 INFO L276 IsEmpty]: Start isEmpty. Operand 143 states and 161 transitions. [2022-04-08 13:27:59,749 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:27:59,749 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:27:59,749 INFO L74 IsIncluded]: Start isIncluded. First operand has 143 states, 89 states have (on average 1.101123595505618) internal successors, (98), 92 states have internal predecessors, (98), 33 states have call successors, (33), 21 states have call predecessors, (33), 20 states have return successors, (30), 29 states have call predecessors, (30), 30 states have call successors, (30) Second operand 143 states. [2022-04-08 13:27:59,749 INFO L87 Difference]: Start difference. First operand has 143 states, 89 states have (on average 1.101123595505618) internal successors, (98), 92 states have internal predecessors, (98), 33 states have call successors, (33), 21 states have call predecessors, (33), 20 states have return successors, (30), 29 states have call predecessors, (30), 30 states have call successors, (30) Second operand 143 states. [2022-04-08 13:27:59,751 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:27:59,752 INFO L93 Difference]: Finished difference Result 143 states and 161 transitions. [2022-04-08 13:27:59,752 INFO L276 IsEmpty]: Start isEmpty. Operand 143 states and 161 transitions. [2022-04-08 13:27:59,752 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:27:59,752 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:27:59,752 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-08 13:27:59,752 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-08 13:27:59,752 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 143 states, 89 states have (on average 1.101123595505618) internal successors, (98), 92 states have internal predecessors, (98), 33 states have call successors, (33), 21 states have call predecessors, (33), 20 states have return successors, (30), 29 states have call predecessors, (30), 30 states have call successors, (30) [2022-04-08 13:27:59,754 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 143 states to 143 states and 161 transitions. [2022-04-08 13:27:59,755 INFO L78 Accepts]: Start accepts. Automaton has 143 states and 161 transitions. Word has length 105 [2022-04-08 13:27:59,755 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-08 13:27:59,755 INFO L478 AbstractCegarLoop]: Abstraction has 143 states and 161 transitions. [2022-04-08 13:27:59,757 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 11 states, 10 states have (on average 2.7) internal successors, (27), 10 states have internal predecessors, (27), 7 states have call successors, (19), 2 states have call predecessors, (19), 1 states have return successors, (17), 6 states have call predecessors, (17), 6 states have call successors, (17) [2022-04-08 13:27:59,757 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 143 states and 161 transitions. [2022-04-08 13:27:59,939 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 161 edges. 161 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:27:59,940 INFO L276 IsEmpty]: Start isEmpty. Operand 143 states and 161 transitions. [2022-04-08 13:27:59,940 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 106 [2022-04-08 13:27:59,940 INFO L491 BasicCegarLoop]: Found error trace [2022-04-08 13:27:59,940 INFO L499 BasicCegarLoop]: trace histogram [16, 15, 15, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-08 13:27:59,972 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (12)] Forceful destruction successful, exit code 0 [2022-04-08 13:28:00,167 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 12 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable13 [2022-04-08 13:28:00,168 INFO L403 AbstractCegarLoop]: === Iteration 15 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-08 13:28:00,168 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-08 13:28:00,168 INFO L85 PathProgramCache]: Analyzing trace with hash 1328912794, now seen corresponding path program 1 times [2022-04-08 13:28:00,168 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-08 13:28:00,168 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [2045115355] [2022-04-08 13:28:03,420 INFO L97 AcceleratorQvasr]: Qvasr could not accelerate loop because java.lang.UnsupportedOperationException: Cannot deal with arrays. [2022-04-08 13:28:03,420 INFO L274 tedInterpolationCore]: Could not compute an accelerate. [2022-04-08 13:28:03,421 INFO L85 PathProgramCache]: Analyzing trace with hash 1328912794, now seen corresponding path program 2 times [2022-04-08 13:28:03,421 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-08 13:28:03,421 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1548033938] [2022-04-08 13:28:03,421 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-08 13:28:03,421 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-08 13:28:03,430 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-08 13:28:03,431 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1187120465] [2022-04-08 13:28:03,431 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-08 13:28:03,431 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:28:03,431 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-08 13:28:03,432 INFO L229 MonitoredProcess]: Starting monitored process 13 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-08 13:28:03,432 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (13)] Waiting until timeout for monitored process [2022-04-08 13:28:03,492 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-08 13:28:03,493 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-08 13:28:03,494 INFO L263 TraceCheckSpWp]: Trace formula consists of 241 conjuncts, 8 conjunts are in the unsatisfiable core [2022-04-08 13:28:03,506 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:28:03,507 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-08 13:28:05,262 INFO L272 TraceCheckUtils]: 0: Hoare triple {12736#true} call ULTIMATE.init(); {12736#true} is VALID [2022-04-08 13:28:05,262 INFO L290 TraceCheckUtils]: 1: Hoare triple {12736#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {12736#true} is VALID [2022-04-08 13:28:05,262 INFO L290 TraceCheckUtils]: 2: Hoare triple {12736#true} assume true; {12736#true} is VALID [2022-04-08 13:28:05,262 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {12736#true} {12736#true} #94#return; {12736#true} is VALID [2022-04-08 13:28:05,263 INFO L272 TraceCheckUtils]: 4: Hoare triple {12736#true} call #t~ret5 := main(); {12736#true} is VALID [2022-04-08 13:28:05,263 INFO L290 TraceCheckUtils]: 5: Hoare triple {12736#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {12736#true} is VALID [2022-04-08 13:28:05,263 INFO L272 TraceCheckUtils]: 6: Hoare triple {12736#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {12736#true} is VALID [2022-04-08 13:28:05,263 INFO L290 TraceCheckUtils]: 7: Hoare triple {12736#true} ~cond := #in~cond; {12736#true} is VALID [2022-04-08 13:28:05,263 INFO L290 TraceCheckUtils]: 8: Hoare triple {12736#true} assume !(0 == ~cond); {12736#true} is VALID [2022-04-08 13:28:05,263 INFO L290 TraceCheckUtils]: 9: Hoare triple {12736#true} assume true; {12736#true} is VALID [2022-04-08 13:28:05,263 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {12736#true} {12736#true} #78#return; {12736#true} is VALID [2022-04-08 13:28:05,264 INFO L290 TraceCheckUtils]: 11: Hoare triple {12736#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {12774#(<= 1 main_~d~0)} is VALID [2022-04-08 13:28:05,264 INFO L290 TraceCheckUtils]: 12: Hoare triple {12774#(<= 1 main_~d~0)} assume !false; {12774#(<= 1 main_~d~0)} is VALID [2022-04-08 13:28:05,264 INFO L272 TraceCheckUtils]: 13: Hoare triple {12774#(<= 1 main_~d~0)} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {12736#true} is VALID [2022-04-08 13:28:05,264 INFO L290 TraceCheckUtils]: 14: Hoare triple {12736#true} ~cond := #in~cond; {12736#true} is VALID [2022-04-08 13:28:05,264 INFO L290 TraceCheckUtils]: 15: Hoare triple {12736#true} assume !(0 == ~cond); {12736#true} is VALID [2022-04-08 13:28:05,264 INFO L290 TraceCheckUtils]: 16: Hoare triple {12736#true} assume true; {12736#true} is VALID [2022-04-08 13:28:05,265 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {12736#true} {12774#(<= 1 main_~d~0)} #80#return; {12774#(<= 1 main_~d~0)} is VALID [2022-04-08 13:28:05,265 INFO L272 TraceCheckUtils]: 18: Hoare triple {12774#(<= 1 main_~d~0)} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {12736#true} is VALID [2022-04-08 13:28:05,265 INFO L290 TraceCheckUtils]: 19: Hoare triple {12736#true} ~cond := #in~cond; {12736#true} is VALID [2022-04-08 13:28:05,265 INFO L290 TraceCheckUtils]: 20: Hoare triple {12736#true} assume !(0 == ~cond); {12736#true} is VALID [2022-04-08 13:28:05,265 INFO L290 TraceCheckUtils]: 21: Hoare triple {12736#true} assume true; {12736#true} is VALID [2022-04-08 13:28:05,265 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {12736#true} {12774#(<= 1 main_~d~0)} #82#return; {12774#(<= 1 main_~d~0)} is VALID [2022-04-08 13:28:05,265 INFO L272 TraceCheckUtils]: 23: Hoare triple {12774#(<= 1 main_~d~0)} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {12736#true} is VALID [2022-04-08 13:28:05,265 INFO L290 TraceCheckUtils]: 24: Hoare triple {12736#true} ~cond := #in~cond; {12736#true} is VALID [2022-04-08 13:28:05,265 INFO L290 TraceCheckUtils]: 25: Hoare triple {12736#true} assume !(0 == ~cond); {12736#true} is VALID [2022-04-08 13:28:05,265 INFO L290 TraceCheckUtils]: 26: Hoare triple {12736#true} assume true; {12736#true} is VALID [2022-04-08 13:28:05,266 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {12736#true} {12774#(<= 1 main_~d~0)} #84#return; {12774#(<= 1 main_~d~0)} is VALID [2022-04-08 13:28:05,266 INFO L290 TraceCheckUtils]: 28: Hoare triple {12774#(<= 1 main_~d~0)} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {12826#(<= 1 (div main_~d~0 2))} is VALID [2022-04-08 13:28:05,267 INFO L290 TraceCheckUtils]: 29: Hoare triple {12826#(<= 1 (div main_~d~0 2))} assume !false; {12826#(<= 1 (div main_~d~0 2))} is VALID [2022-04-08 13:28:05,267 INFO L272 TraceCheckUtils]: 30: Hoare triple {12826#(<= 1 (div main_~d~0 2))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {12736#true} is VALID [2022-04-08 13:28:05,267 INFO L290 TraceCheckUtils]: 31: Hoare triple {12736#true} ~cond := #in~cond; {12736#true} is VALID [2022-04-08 13:28:05,267 INFO L290 TraceCheckUtils]: 32: Hoare triple {12736#true} assume !(0 == ~cond); {12736#true} is VALID [2022-04-08 13:28:05,267 INFO L290 TraceCheckUtils]: 33: Hoare triple {12736#true} assume true; {12736#true} is VALID [2022-04-08 13:28:05,267 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {12736#true} {12826#(<= 1 (div main_~d~0 2))} #80#return; {12826#(<= 1 (div main_~d~0 2))} is VALID [2022-04-08 13:28:05,267 INFO L272 TraceCheckUtils]: 35: Hoare triple {12826#(<= 1 (div main_~d~0 2))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {12736#true} is VALID [2022-04-08 13:28:05,267 INFO L290 TraceCheckUtils]: 36: Hoare triple {12736#true} ~cond := #in~cond; {12736#true} is VALID [2022-04-08 13:28:05,268 INFO L290 TraceCheckUtils]: 37: Hoare triple {12736#true} assume !(0 == ~cond); {12736#true} is VALID [2022-04-08 13:28:05,268 INFO L290 TraceCheckUtils]: 38: Hoare triple {12736#true} assume true; {12736#true} is VALID [2022-04-08 13:28:05,268 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {12736#true} {12826#(<= 1 (div main_~d~0 2))} #82#return; {12826#(<= 1 (div main_~d~0 2))} is VALID [2022-04-08 13:28:05,268 INFO L272 TraceCheckUtils]: 40: Hoare triple {12826#(<= 1 (div main_~d~0 2))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {12736#true} is VALID [2022-04-08 13:28:05,268 INFO L290 TraceCheckUtils]: 41: Hoare triple {12736#true} ~cond := #in~cond; {12736#true} is VALID [2022-04-08 13:28:05,268 INFO L290 TraceCheckUtils]: 42: Hoare triple {12736#true} assume !(0 == ~cond); {12736#true} is VALID [2022-04-08 13:28:05,268 INFO L290 TraceCheckUtils]: 43: Hoare triple {12736#true} assume true; {12736#true} is VALID [2022-04-08 13:28:05,269 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {12736#true} {12826#(<= 1 (div main_~d~0 2))} #84#return; {12826#(<= 1 (div main_~d~0 2))} is VALID [2022-04-08 13:28:05,269 INFO L290 TraceCheckUtils]: 45: Hoare triple {12826#(<= 1 (div main_~d~0 2))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} is VALID [2022-04-08 13:28:05,270 INFO L290 TraceCheckUtils]: 46: Hoare triple {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} assume !false; {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} is VALID [2022-04-08 13:28:05,270 INFO L272 TraceCheckUtils]: 47: Hoare triple {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {12736#true} is VALID [2022-04-08 13:28:05,270 INFO L290 TraceCheckUtils]: 48: Hoare triple {12736#true} ~cond := #in~cond; {12736#true} is VALID [2022-04-08 13:28:05,270 INFO L290 TraceCheckUtils]: 49: Hoare triple {12736#true} assume !(0 == ~cond); {12736#true} is VALID [2022-04-08 13:28:05,270 INFO L290 TraceCheckUtils]: 50: Hoare triple {12736#true} assume true; {12736#true} is VALID [2022-04-08 13:28:05,270 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {12736#true} {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} #80#return; {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} is VALID [2022-04-08 13:28:05,270 INFO L272 TraceCheckUtils]: 52: Hoare triple {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {12736#true} is VALID [2022-04-08 13:28:05,270 INFO L290 TraceCheckUtils]: 53: Hoare triple {12736#true} ~cond := #in~cond; {12736#true} is VALID [2022-04-08 13:28:05,271 INFO L290 TraceCheckUtils]: 54: Hoare triple {12736#true} assume !(0 == ~cond); {12736#true} is VALID [2022-04-08 13:28:05,271 INFO L290 TraceCheckUtils]: 55: Hoare triple {12736#true} assume true; {12736#true} is VALID [2022-04-08 13:28:05,271 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {12736#true} {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} #82#return; {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} is VALID [2022-04-08 13:28:05,271 INFO L272 TraceCheckUtils]: 57: Hoare triple {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {12736#true} is VALID [2022-04-08 13:28:05,271 INFO L290 TraceCheckUtils]: 58: Hoare triple {12736#true} ~cond := #in~cond; {12736#true} is VALID [2022-04-08 13:28:05,271 INFO L290 TraceCheckUtils]: 59: Hoare triple {12736#true} assume !(0 == ~cond); {12736#true} is VALID [2022-04-08 13:28:05,271 INFO L290 TraceCheckUtils]: 60: Hoare triple {12736#true} assume true; {12736#true} is VALID [2022-04-08 13:28:05,272 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {12736#true} {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} #84#return; {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} is VALID [2022-04-08 13:28:05,272 INFO L290 TraceCheckUtils]: 62: Hoare triple {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} assume !(~r~0 >= ~d~0); {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} is VALID [2022-04-08 13:28:05,272 INFO L290 TraceCheckUtils]: 63: Hoare triple {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} assume !false; {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} is VALID [2022-04-08 13:28:05,272 INFO L272 TraceCheckUtils]: 64: Hoare triple {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {12736#true} is VALID [2022-04-08 13:28:05,272 INFO L290 TraceCheckUtils]: 65: Hoare triple {12736#true} ~cond := #in~cond; {12736#true} is VALID [2022-04-08 13:28:05,272 INFO L290 TraceCheckUtils]: 66: Hoare triple {12736#true} assume !(0 == ~cond); {12736#true} is VALID [2022-04-08 13:28:05,273 INFO L290 TraceCheckUtils]: 67: Hoare triple {12736#true} assume true; {12736#true} is VALID [2022-04-08 13:28:05,273 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {12736#true} {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} #86#return; {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} is VALID [2022-04-08 13:28:05,273 INFO L272 TraceCheckUtils]: 69: Hoare triple {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {12736#true} is VALID [2022-04-08 13:28:05,273 INFO L290 TraceCheckUtils]: 70: Hoare triple {12736#true} ~cond := #in~cond; {12736#true} is VALID [2022-04-08 13:28:05,273 INFO L290 TraceCheckUtils]: 71: Hoare triple {12736#true} assume !(0 == ~cond); {12736#true} is VALID [2022-04-08 13:28:05,273 INFO L290 TraceCheckUtils]: 72: Hoare triple {12736#true} assume true; {12736#true} is VALID [2022-04-08 13:28:05,274 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {12736#true} {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} #88#return; {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} is VALID [2022-04-08 13:28:05,275 INFO L290 TraceCheckUtils]: 74: Hoare triple {12878#(and (<= (div main_~d~0 2) main_~r~0) (= (mod main_~d~0 2) 0) (<= 1 (div (div main_~d~0 2) 2)))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {12966#(and (< 0 (div main_~r~0 2)) (< main_~d~0 (+ main_~r~0 1)))} is VALID [2022-04-08 13:28:05,275 INFO L290 TraceCheckUtils]: 75: Hoare triple {12966#(and (< 0 (div main_~r~0 2)) (< main_~d~0 (+ main_~r~0 1)))} assume !(~r~0 >= ~d~0); {12737#false} is VALID [2022-04-08 13:28:05,275 INFO L290 TraceCheckUtils]: 76: Hoare triple {12737#false} assume !false; {12737#false} is VALID [2022-04-08 13:28:05,275 INFO L272 TraceCheckUtils]: 77: Hoare triple {12737#false} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {12737#false} is VALID [2022-04-08 13:28:05,275 INFO L290 TraceCheckUtils]: 78: Hoare triple {12737#false} ~cond := #in~cond; {12737#false} is VALID [2022-04-08 13:28:05,275 INFO L290 TraceCheckUtils]: 79: Hoare triple {12737#false} assume !(0 == ~cond); {12737#false} is VALID [2022-04-08 13:28:05,275 INFO L290 TraceCheckUtils]: 80: Hoare triple {12737#false} assume true; {12737#false} is VALID [2022-04-08 13:28:05,276 INFO L284 TraceCheckUtils]: 81: Hoare quadruple {12737#false} {12737#false} #86#return; {12737#false} is VALID [2022-04-08 13:28:05,276 INFO L272 TraceCheckUtils]: 82: Hoare triple {12737#false} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {12737#false} is VALID [2022-04-08 13:28:05,276 INFO L290 TraceCheckUtils]: 83: Hoare triple {12737#false} ~cond := #in~cond; {12737#false} is VALID [2022-04-08 13:28:05,276 INFO L290 TraceCheckUtils]: 84: Hoare triple {12737#false} assume !(0 == ~cond); {12737#false} is VALID [2022-04-08 13:28:05,276 INFO L290 TraceCheckUtils]: 85: Hoare triple {12737#false} assume true; {12737#false} is VALID [2022-04-08 13:28:05,276 INFO L284 TraceCheckUtils]: 86: Hoare quadruple {12737#false} {12737#false} #88#return; {12737#false} is VALID [2022-04-08 13:28:05,276 INFO L290 TraceCheckUtils]: 87: Hoare triple {12737#false} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {12737#false} is VALID [2022-04-08 13:28:05,276 INFO L290 TraceCheckUtils]: 88: Hoare triple {12737#false} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {12737#false} is VALID [2022-04-08 13:28:05,276 INFO L290 TraceCheckUtils]: 89: Hoare triple {12737#false} assume !false; {12737#false} is VALID [2022-04-08 13:28:05,276 INFO L272 TraceCheckUtils]: 90: Hoare triple {12737#false} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {12737#false} is VALID [2022-04-08 13:28:05,276 INFO L290 TraceCheckUtils]: 91: Hoare triple {12737#false} ~cond := #in~cond; {12737#false} is VALID [2022-04-08 13:28:05,276 INFO L290 TraceCheckUtils]: 92: Hoare triple {12737#false} assume !(0 == ~cond); {12737#false} is VALID [2022-04-08 13:28:05,276 INFO L290 TraceCheckUtils]: 93: Hoare triple {12737#false} assume true; {12737#false} is VALID [2022-04-08 13:28:05,276 INFO L284 TraceCheckUtils]: 94: Hoare quadruple {12737#false} {12737#false} #86#return; {12737#false} is VALID [2022-04-08 13:28:05,276 INFO L272 TraceCheckUtils]: 95: Hoare triple {12737#false} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {12737#false} is VALID [2022-04-08 13:28:05,276 INFO L290 TraceCheckUtils]: 96: Hoare triple {12737#false} ~cond := #in~cond; {12737#false} is VALID [2022-04-08 13:28:05,276 INFO L290 TraceCheckUtils]: 97: Hoare triple {12737#false} assume !(0 == ~cond); {12737#false} is VALID [2022-04-08 13:28:05,276 INFO L290 TraceCheckUtils]: 98: Hoare triple {12737#false} assume true; {12737#false} is VALID [2022-04-08 13:28:05,277 INFO L284 TraceCheckUtils]: 99: Hoare quadruple {12737#false} {12737#false} #88#return; {12737#false} is VALID [2022-04-08 13:28:05,277 INFO L290 TraceCheckUtils]: 100: Hoare triple {12737#false} assume !(1 != ~p~0); {12737#false} is VALID [2022-04-08 13:28:05,277 INFO L272 TraceCheckUtils]: 101: Hoare triple {12737#false} call __VERIFIER_assert((if ~A~0 == ~d~0 * ~q~0 + ~r~0 then 1 else 0)); {12737#false} is VALID [2022-04-08 13:28:05,277 INFO L290 TraceCheckUtils]: 102: Hoare triple {12737#false} ~cond := #in~cond; {12737#false} is VALID [2022-04-08 13:28:05,277 INFO L290 TraceCheckUtils]: 103: Hoare triple {12737#false} assume 0 == ~cond; {12737#false} is VALID [2022-04-08 13:28:05,277 INFO L290 TraceCheckUtils]: 104: Hoare triple {12737#false} assume !false; {12737#false} is VALID [2022-04-08 13:28:05,277 INFO L134 CoverageAnalysis]: Checked inductivity of 478 backedges. 222 proven. 0 refuted. 0 times theorem prover too weak. 256 trivial. 0 not checked. [2022-04-08 13:28:05,277 INFO L324 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2022-04-08 13:28:05,277 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-08 13:28:05,277 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1548033938] [2022-04-08 13:28:05,277 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-08 13:28:05,278 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1187120465] [2022-04-08 13:28:05,278 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1187120465] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:28:05,278 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:28:05,278 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [6] imperfect sequences [] total 6 [2022-04-08 13:28:05,278 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-08 13:28:05,278 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [2045115355] [2022-04-08 13:28:05,278 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [2045115355] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:28:05,278 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:28:05,278 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [6] imperfect sequences [] total 6 [2022-04-08 13:28:05,278 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1246581783] [2022-04-08 13:28:05,278 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-08 13:28:05,278 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 4.666666666666667) internal successors, (28), 6 states have internal predecessors, (28), 5 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (15), 5 states have call predecessors, (15), 5 states have call successors, (15) Word has length 105 [2022-04-08 13:28:05,279 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-08 13:28:05,279 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 6 states, 6 states have (on average 4.666666666666667) internal successors, (28), 6 states have internal predecessors, (28), 5 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (15), 5 states have call predecessors, (15), 5 states have call successors, (15) [2022-04-08 13:28:05,322 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 60 edges. 60 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:28:05,322 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 6 states [2022-04-08 13:28:05,323 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-08 13:28:05,323 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 6 interpolants. [2022-04-08 13:28:05,323 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=12, Invalid=18, Unknown=0, NotChecked=0, Total=30 [2022-04-08 13:28:05,323 INFO L87 Difference]: Start difference. First operand 143 states and 161 transitions. Second operand has 6 states, 6 states have (on average 4.666666666666667) internal successors, (28), 6 states have internal predecessors, (28), 5 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (15), 5 states have call predecessors, (15), 5 states have call successors, (15) [2022-04-08 13:28:05,805 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:28:05,806 INFO L93 Difference]: Finished difference Result 195 states and 230 transitions. [2022-04-08 13:28:05,806 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 6 states. [2022-04-08 13:28:05,806 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 4.666666666666667) internal successors, (28), 6 states have internal predecessors, (28), 5 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (15), 5 states have call predecessors, (15), 5 states have call successors, (15) Word has length 105 [2022-04-08 13:28:05,806 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-08 13:28:05,806 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 4.666666666666667) internal successors, (28), 6 states have internal predecessors, (28), 5 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (15), 5 states have call predecessors, (15), 5 states have call successors, (15) [2022-04-08 13:28:05,807 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 6 states to 6 states and 101 transitions. [2022-04-08 13:28:05,807 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 4.666666666666667) internal successors, (28), 6 states have internal predecessors, (28), 5 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (15), 5 states have call predecessors, (15), 5 states have call successors, (15) [2022-04-08 13:28:05,808 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 6 states to 6 states and 101 transitions. [2022-04-08 13:28:05,808 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 6 states and 101 transitions. [2022-04-08 13:28:05,919 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 101 edges. 101 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:28:05,921 INFO L225 Difference]: With dead ends: 195 [2022-04-08 13:28:05,921 INFO L226 Difference]: Without dead ends: 124 [2022-04-08 13:28:05,921 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 105 GetRequests, 100 SyntacticMatches, 0 SemanticMatches, 5 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 2 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=17, Invalid=25, Unknown=0, NotChecked=0, Total=42 [2022-04-08 13:28:05,922 INFO L913 BasicCegarLoop]: 55 mSDtfsCounter, 8 mSDsluCounter, 102 mSDsCounter, 0 mSdLazyCounter, 102 mSolverCounterSat, 6 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.1s Time, 0 mProtectedPredicate, 0 mProtectedAction, 14 SdHoareTripleChecker+Valid, 157 SdHoareTripleChecker+Invalid, 108 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 6 IncrementalHoareTripleChecker+Valid, 102 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.1s IncrementalHoareTripleChecker+Time [2022-04-08 13:28:05,922 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [14 Valid, 157 Invalid, 108 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [6 Valid, 102 Invalid, 0 Unknown, 0 Unchecked, 0.1s Time] [2022-04-08 13:28:05,922 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 124 states. [2022-04-08 13:28:06,008 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 124 to 107. [2022-04-08 13:28:06,008 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-08 13:28:06,008 INFO L82 GeneralOperation]: Start isEquivalent. First operand 124 states. Second operand has 107 states, 67 states have (on average 1.0895522388059702) internal successors, (73), 68 states have internal predecessors, (73), 23 states have call successors, (23), 17 states have call predecessors, (23), 16 states have return successors, (21), 21 states have call predecessors, (21), 21 states have call successors, (21) [2022-04-08 13:28:06,008 INFO L74 IsIncluded]: Start isIncluded. First operand 124 states. Second operand has 107 states, 67 states have (on average 1.0895522388059702) internal successors, (73), 68 states have internal predecessors, (73), 23 states have call successors, (23), 17 states have call predecessors, (23), 16 states have return successors, (21), 21 states have call predecessors, (21), 21 states have call successors, (21) [2022-04-08 13:28:06,017 INFO L87 Difference]: Start difference. First operand 124 states. Second operand has 107 states, 67 states have (on average 1.0895522388059702) internal successors, (73), 68 states have internal predecessors, (73), 23 states have call successors, (23), 17 states have call predecessors, (23), 16 states have return successors, (21), 21 states have call predecessors, (21), 21 states have call successors, (21) [2022-04-08 13:28:06,020 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:28:06,021 INFO L93 Difference]: Finished difference Result 124 states and 146 transitions. [2022-04-08 13:28:06,021 INFO L276 IsEmpty]: Start isEmpty. Operand 124 states and 146 transitions. [2022-04-08 13:28:06,021 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:28:06,021 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:28:06,021 INFO L74 IsIncluded]: Start isIncluded. First operand has 107 states, 67 states have (on average 1.0895522388059702) internal successors, (73), 68 states have internal predecessors, (73), 23 states have call successors, (23), 17 states have call predecessors, (23), 16 states have return successors, (21), 21 states have call predecessors, (21), 21 states have call successors, (21) Second operand 124 states. [2022-04-08 13:28:06,021 INFO L87 Difference]: Start difference. First operand has 107 states, 67 states have (on average 1.0895522388059702) internal successors, (73), 68 states have internal predecessors, (73), 23 states have call successors, (23), 17 states have call predecessors, (23), 16 states have return successors, (21), 21 states have call predecessors, (21), 21 states have call successors, (21) Second operand 124 states. [2022-04-08 13:28:06,023 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:28:06,023 INFO L93 Difference]: Finished difference Result 124 states and 146 transitions. [2022-04-08 13:28:06,024 INFO L276 IsEmpty]: Start isEmpty. Operand 124 states and 146 transitions. [2022-04-08 13:28:06,024 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:28:06,024 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:28:06,024 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-08 13:28:06,024 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-08 13:28:06,024 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 107 states, 67 states have (on average 1.0895522388059702) internal successors, (73), 68 states have internal predecessors, (73), 23 states have call successors, (23), 17 states have call predecessors, (23), 16 states have return successors, (21), 21 states have call predecessors, (21), 21 states have call successors, (21) [2022-04-08 13:28:06,025 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 107 states to 107 states and 117 transitions. [2022-04-08 13:28:06,026 INFO L78 Accepts]: Start accepts. Automaton has 107 states and 117 transitions. Word has length 105 [2022-04-08 13:28:06,026 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-08 13:28:06,026 INFO L478 AbstractCegarLoop]: Abstraction has 107 states and 117 transitions. [2022-04-08 13:28:06,026 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 6 states, 6 states have (on average 4.666666666666667) internal successors, (28), 6 states have internal predecessors, (28), 5 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (15), 5 states have call predecessors, (15), 5 states have call successors, (15) [2022-04-08 13:28:06,027 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 107 states and 117 transitions. [2022-04-08 13:28:06,183 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 117 edges. 117 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:28:06,183 INFO L276 IsEmpty]: Start isEmpty. Operand 107 states and 117 transitions. [2022-04-08 13:28:06,184 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 110 [2022-04-08 13:28:06,184 INFO L491 BasicCegarLoop]: Found error trace [2022-04-08 13:28:06,184 INFO L499 BasicCegarLoop]: trace histogram [17, 16, 16, 4, 4, 4, 4, 4, 4, 4, 3, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-08 13:28:06,201 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (13)] Forceful destruction successful, exit code 0 [2022-04-08 13:28:06,385 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 13 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable14 [2022-04-08 13:28:06,385 INFO L403 AbstractCegarLoop]: === Iteration 16 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-08 13:28:06,385 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-08 13:28:06,385 INFO L85 PathProgramCache]: Analyzing trace with hash -416382532, now seen corresponding path program 5 times [2022-04-08 13:28:06,387 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-08 13:28:06,387 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [1623895039] [2022-04-08 13:28:08,820 INFO L97 AcceleratorQvasr]: Qvasr could not accelerate loop because java.lang.UnsupportedOperationException: Cannot deal with arrays. [2022-04-08 13:28:08,820 INFO L274 tedInterpolationCore]: Could not compute an accelerate. [2022-04-08 13:28:08,820 INFO L85 PathProgramCache]: Analyzing trace with hash -416382532, now seen corresponding path program 6 times [2022-04-08 13:28:08,820 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-08 13:28:08,820 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [614031993] [2022-04-08 13:28:08,820 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-08 13:28:08,820 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-08 13:28:08,837 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-08 13:28:08,838 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [128005726] [2022-04-08 13:28:08,838 INFO L93 rtionOrderModulation]: Changing assertion order to MIX_INSIDE_OUTSIDE [2022-04-08 13:28:08,838 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:28:08,838 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-08 13:28:08,839 INFO L229 MonitoredProcess]: Starting monitored process 14 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-08 13:28:08,840 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (14)] Waiting until timeout for monitored process [2022-04-08 13:28:08,886 INFO L228 tOrderPrioritization]: Assert order MIX_INSIDE_OUTSIDE issued 7 check-sat command(s) [2022-04-08 13:28:08,886 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-08 13:28:08,887 INFO L263 TraceCheckSpWp]: Trace formula consists of 231 conjuncts, 6 conjunts are in the unsatisfiable core [2022-04-08 13:28:08,901 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:28:08,902 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-08 13:28:11,424 INFO L272 TraceCheckUtils]: 0: Hoare triple {13910#true} call ULTIMATE.init(); {13910#true} is VALID [2022-04-08 13:28:11,424 INFO L290 TraceCheckUtils]: 1: Hoare triple {13910#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {13910#true} is VALID [2022-04-08 13:28:11,424 INFO L290 TraceCheckUtils]: 2: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:11,424 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {13910#true} {13910#true} #94#return; {13910#true} is VALID [2022-04-08 13:28:11,424 INFO L272 TraceCheckUtils]: 4: Hoare triple {13910#true} call #t~ret5 := main(); {13910#true} is VALID [2022-04-08 13:28:11,424 INFO L290 TraceCheckUtils]: 5: Hoare triple {13910#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {13910#true} is VALID [2022-04-08 13:28:11,424 INFO L272 TraceCheckUtils]: 6: Hoare triple {13910#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:11,424 INFO L290 TraceCheckUtils]: 7: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:11,425 INFO L290 TraceCheckUtils]: 8: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:11,425 INFO L290 TraceCheckUtils]: 9: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:11,425 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {13910#true} {13910#true} #78#return; {13910#true} is VALID [2022-04-08 13:28:11,425 INFO L290 TraceCheckUtils]: 11: Hoare triple {13910#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {13948#(<= 1 main_~p~0)} is VALID [2022-04-08 13:28:11,425 INFO L290 TraceCheckUtils]: 12: Hoare triple {13948#(<= 1 main_~p~0)} assume !false; {13948#(<= 1 main_~p~0)} is VALID [2022-04-08 13:28:11,425 INFO L272 TraceCheckUtils]: 13: Hoare triple {13948#(<= 1 main_~p~0)} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:11,425 INFO L290 TraceCheckUtils]: 14: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:11,425 INFO L290 TraceCheckUtils]: 15: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:11,426 INFO L290 TraceCheckUtils]: 16: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:11,426 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {13910#true} {13948#(<= 1 main_~p~0)} #80#return; {13948#(<= 1 main_~p~0)} is VALID [2022-04-08 13:28:11,426 INFO L272 TraceCheckUtils]: 18: Hoare triple {13948#(<= 1 main_~p~0)} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:11,426 INFO L290 TraceCheckUtils]: 19: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:11,426 INFO L290 TraceCheckUtils]: 20: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:11,426 INFO L290 TraceCheckUtils]: 21: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:11,427 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {13910#true} {13948#(<= 1 main_~p~0)} #82#return; {13948#(<= 1 main_~p~0)} is VALID [2022-04-08 13:28:11,427 INFO L272 TraceCheckUtils]: 23: Hoare triple {13948#(<= 1 main_~p~0)} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:11,427 INFO L290 TraceCheckUtils]: 24: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:11,427 INFO L290 TraceCheckUtils]: 25: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:11,427 INFO L290 TraceCheckUtils]: 26: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:11,427 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {13910#true} {13948#(<= 1 main_~p~0)} #84#return; {13948#(<= 1 main_~p~0)} is VALID [2022-04-08 13:28:11,428 INFO L290 TraceCheckUtils]: 28: Hoare triple {13948#(<= 1 main_~p~0)} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {14000#(<= 1 (div main_~p~0 2))} is VALID [2022-04-08 13:28:11,428 INFO L290 TraceCheckUtils]: 29: Hoare triple {14000#(<= 1 (div main_~p~0 2))} assume !false; {14000#(<= 1 (div main_~p~0 2))} is VALID [2022-04-08 13:28:11,428 INFO L272 TraceCheckUtils]: 30: Hoare triple {14000#(<= 1 (div main_~p~0 2))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:11,428 INFO L290 TraceCheckUtils]: 31: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:11,428 INFO L290 TraceCheckUtils]: 32: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:11,428 INFO L290 TraceCheckUtils]: 33: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:11,429 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {13910#true} {14000#(<= 1 (div main_~p~0 2))} #80#return; {14000#(<= 1 (div main_~p~0 2))} is VALID [2022-04-08 13:28:11,429 INFO L272 TraceCheckUtils]: 35: Hoare triple {14000#(<= 1 (div main_~p~0 2))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:11,429 INFO L290 TraceCheckUtils]: 36: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:11,429 INFO L290 TraceCheckUtils]: 37: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:11,429 INFO L290 TraceCheckUtils]: 38: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:11,429 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {13910#true} {14000#(<= 1 (div main_~p~0 2))} #82#return; {14000#(<= 1 (div main_~p~0 2))} is VALID [2022-04-08 13:28:11,429 INFO L272 TraceCheckUtils]: 40: Hoare triple {14000#(<= 1 (div main_~p~0 2))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:11,430 INFO L290 TraceCheckUtils]: 41: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:11,430 INFO L290 TraceCheckUtils]: 42: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:11,430 INFO L290 TraceCheckUtils]: 43: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:11,430 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {13910#true} {14000#(<= 1 (div main_~p~0 2))} #84#return; {14000#(<= 1 (div main_~p~0 2))} is VALID [2022-04-08 13:28:11,431 INFO L290 TraceCheckUtils]: 45: Hoare triple {14000#(<= 1 (div main_~p~0 2))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {14052#(<= 1 (div (div main_~p~0 2) 2))} is VALID [2022-04-08 13:28:11,431 INFO L290 TraceCheckUtils]: 46: Hoare triple {14052#(<= 1 (div (div main_~p~0 2) 2))} assume !false; {14052#(<= 1 (div (div main_~p~0 2) 2))} is VALID [2022-04-08 13:28:11,431 INFO L272 TraceCheckUtils]: 47: Hoare triple {14052#(<= 1 (div (div main_~p~0 2) 2))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:11,431 INFO L290 TraceCheckUtils]: 48: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:11,431 INFO L290 TraceCheckUtils]: 49: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:11,431 INFO L290 TraceCheckUtils]: 50: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:11,431 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {13910#true} {14052#(<= 1 (div (div main_~p~0 2) 2))} #80#return; {14052#(<= 1 (div (div main_~p~0 2) 2))} is VALID [2022-04-08 13:28:11,432 INFO L272 TraceCheckUtils]: 52: Hoare triple {14052#(<= 1 (div (div main_~p~0 2) 2))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:11,432 INFO L290 TraceCheckUtils]: 53: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:11,432 INFO L290 TraceCheckUtils]: 54: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:11,432 INFO L290 TraceCheckUtils]: 55: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:11,432 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {13910#true} {14052#(<= 1 (div (div main_~p~0 2) 2))} #82#return; {14052#(<= 1 (div (div main_~p~0 2) 2))} is VALID [2022-04-08 13:28:11,432 INFO L272 TraceCheckUtils]: 57: Hoare triple {14052#(<= 1 (div (div main_~p~0 2) 2))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:11,432 INFO L290 TraceCheckUtils]: 58: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:11,432 INFO L290 TraceCheckUtils]: 59: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:11,433 INFO L290 TraceCheckUtils]: 60: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:11,435 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {13910#true} {14052#(<= 1 (div (div main_~p~0 2) 2))} #84#return; {14052#(<= 1 (div (div main_~p~0 2) 2))} is VALID [2022-04-08 13:28:11,436 INFO L290 TraceCheckUtils]: 62: Hoare triple {14052#(<= 1 (div (div main_~p~0 2) 2))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} is VALID [2022-04-08 13:28:11,437 INFO L290 TraceCheckUtils]: 63: Hoare triple {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} assume !false; {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} is VALID [2022-04-08 13:28:11,437 INFO L272 TraceCheckUtils]: 64: Hoare triple {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:11,437 INFO L290 TraceCheckUtils]: 65: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:11,437 INFO L290 TraceCheckUtils]: 66: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:11,437 INFO L290 TraceCheckUtils]: 67: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:11,438 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {13910#true} {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} #80#return; {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} is VALID [2022-04-08 13:28:11,438 INFO L272 TraceCheckUtils]: 69: Hoare triple {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:11,438 INFO L290 TraceCheckUtils]: 70: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:11,438 INFO L290 TraceCheckUtils]: 71: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:11,438 INFO L290 TraceCheckUtils]: 72: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:11,438 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {13910#true} {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} #82#return; {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} is VALID [2022-04-08 13:28:11,438 INFO L272 TraceCheckUtils]: 74: Hoare triple {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:11,438 INFO L290 TraceCheckUtils]: 75: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:11,438 INFO L290 TraceCheckUtils]: 76: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:11,439 INFO L290 TraceCheckUtils]: 77: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:11,439 INFO L284 TraceCheckUtils]: 78: Hoare quadruple {13910#true} {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} #84#return; {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} is VALID [2022-04-08 13:28:11,439 INFO L290 TraceCheckUtils]: 79: Hoare triple {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} assume !(~r~0 >= ~d~0); {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} is VALID [2022-04-08 13:28:11,439 INFO L290 TraceCheckUtils]: 80: Hoare triple {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} assume !false; {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} is VALID [2022-04-08 13:28:11,439 INFO L272 TraceCheckUtils]: 81: Hoare triple {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:11,440 INFO L290 TraceCheckUtils]: 82: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:11,440 INFO L290 TraceCheckUtils]: 83: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:11,440 INFO L290 TraceCheckUtils]: 84: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:11,440 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {13910#true} {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} #86#return; {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} is VALID [2022-04-08 13:28:11,440 INFO L272 TraceCheckUtils]: 86: Hoare triple {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:11,440 INFO L290 TraceCheckUtils]: 87: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:11,440 INFO L290 TraceCheckUtils]: 88: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:11,440 INFO L290 TraceCheckUtils]: 89: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:11,441 INFO L284 TraceCheckUtils]: 90: Hoare quadruple {13910#true} {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} #88#return; {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} is VALID [2022-04-08 13:28:11,442 INFO L290 TraceCheckUtils]: 91: Hoare triple {14104#(<= 1 (div (div (div main_~p~0 2) 2) 2))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {14052#(<= 1 (div (div main_~p~0 2) 2))} is VALID [2022-04-08 13:28:11,442 INFO L290 TraceCheckUtils]: 92: Hoare triple {14052#(<= 1 (div (div main_~p~0 2) 2))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {14052#(<= 1 (div (div main_~p~0 2) 2))} is VALID [2022-04-08 13:28:11,442 INFO L290 TraceCheckUtils]: 93: Hoare triple {14052#(<= 1 (div (div main_~p~0 2) 2))} assume !false; {14052#(<= 1 (div (div main_~p~0 2) 2))} is VALID [2022-04-08 13:28:11,443 INFO L272 TraceCheckUtils]: 94: Hoare triple {14052#(<= 1 (div (div main_~p~0 2) 2))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:11,443 INFO L290 TraceCheckUtils]: 95: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:11,443 INFO L290 TraceCheckUtils]: 96: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:11,443 INFO L290 TraceCheckUtils]: 97: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:11,450 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {13910#true} {14052#(<= 1 (div (div main_~p~0 2) 2))} #86#return; {14052#(<= 1 (div (div main_~p~0 2) 2))} is VALID [2022-04-08 13:28:11,450 INFO L272 TraceCheckUtils]: 99: Hoare triple {14052#(<= 1 (div (div main_~p~0 2) 2))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:11,450 INFO L290 TraceCheckUtils]: 100: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:11,450 INFO L290 TraceCheckUtils]: 101: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:11,450 INFO L290 TraceCheckUtils]: 102: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:11,451 INFO L284 TraceCheckUtils]: 103: Hoare quadruple {13910#true} {14052#(<= 1 (div (div main_~p~0 2) 2))} #88#return; {14052#(<= 1 (div (div main_~p~0 2) 2))} is VALID [2022-04-08 13:28:11,451 INFO L290 TraceCheckUtils]: 104: Hoare triple {14052#(<= 1 (div (div main_~p~0 2) 2))} assume !(1 != ~p~0); {13911#false} is VALID [2022-04-08 13:28:11,451 INFO L272 TraceCheckUtils]: 105: Hoare triple {13911#false} call __VERIFIER_assert((if ~A~0 == ~d~0 * ~q~0 + ~r~0 then 1 else 0)); {13911#false} is VALID [2022-04-08 13:28:11,451 INFO L290 TraceCheckUtils]: 106: Hoare triple {13911#false} ~cond := #in~cond; {13911#false} is VALID [2022-04-08 13:28:11,451 INFO L290 TraceCheckUtils]: 107: Hoare triple {13911#false} assume 0 == ~cond; {13911#false} is VALID [2022-04-08 13:28:11,451 INFO L290 TraceCheckUtils]: 108: Hoare triple {13911#false} assume !false; {13911#false} is VALID [2022-04-08 13:28:11,452 INFO L134 CoverageAnalysis]: Checked inductivity of 546 backedges. 62 proven. 4 refuted. 0 times theorem prover too weak. 480 trivial. 0 not checked. [2022-04-08 13:28:11,452 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-08 13:28:12,165 INFO L290 TraceCheckUtils]: 108: Hoare triple {13911#false} assume !false; {13911#false} is VALID [2022-04-08 13:28:12,165 INFO L290 TraceCheckUtils]: 107: Hoare triple {13911#false} assume 0 == ~cond; {13911#false} is VALID [2022-04-08 13:28:12,165 INFO L290 TraceCheckUtils]: 106: Hoare triple {13911#false} ~cond := #in~cond; {13911#false} is VALID [2022-04-08 13:28:12,165 INFO L272 TraceCheckUtils]: 105: Hoare triple {13911#false} call __VERIFIER_assert((if ~A~0 == ~d~0 * ~q~0 + ~r~0 then 1 else 0)); {13911#false} is VALID [2022-04-08 13:28:12,165 INFO L290 TraceCheckUtils]: 104: Hoare triple {14000#(<= 1 (div main_~p~0 2))} assume !(1 != ~p~0); {13911#false} is VALID [2022-04-08 13:28:12,166 INFO L284 TraceCheckUtils]: 103: Hoare quadruple {13910#true} {14000#(<= 1 (div main_~p~0 2))} #88#return; {14000#(<= 1 (div main_~p~0 2))} is VALID [2022-04-08 13:28:12,166 INFO L290 TraceCheckUtils]: 102: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:12,166 INFO L290 TraceCheckUtils]: 101: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:12,166 INFO L290 TraceCheckUtils]: 100: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:12,166 INFO L272 TraceCheckUtils]: 99: Hoare triple {14000#(<= 1 (div main_~p~0 2))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:12,179 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {13910#true} {14000#(<= 1 (div main_~p~0 2))} #86#return; {14000#(<= 1 (div main_~p~0 2))} is VALID [2022-04-08 13:28:12,180 INFO L290 TraceCheckUtils]: 97: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:12,180 INFO L290 TraceCheckUtils]: 96: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:12,180 INFO L290 TraceCheckUtils]: 95: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:12,180 INFO L272 TraceCheckUtils]: 94: Hoare triple {14000#(<= 1 (div main_~p~0 2))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:12,180 INFO L290 TraceCheckUtils]: 93: Hoare triple {14000#(<= 1 (div main_~p~0 2))} assume !false; {14000#(<= 1 (div main_~p~0 2))} is VALID [2022-04-08 13:28:12,180 INFO L290 TraceCheckUtils]: 92: Hoare triple {14000#(<= 1 (div main_~p~0 2))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {14000#(<= 1 (div main_~p~0 2))} is VALID [2022-04-08 13:28:12,182 INFO L290 TraceCheckUtils]: 91: Hoare triple {14052#(<= 1 (div (div main_~p~0 2) 2))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {14000#(<= 1 (div main_~p~0 2))} is VALID [2022-04-08 13:28:12,182 INFO L284 TraceCheckUtils]: 90: Hoare quadruple {13910#true} {14052#(<= 1 (div (div main_~p~0 2) 2))} #88#return; {14052#(<= 1 (div (div main_~p~0 2) 2))} is VALID [2022-04-08 13:28:12,182 INFO L290 TraceCheckUtils]: 89: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:12,182 INFO L290 TraceCheckUtils]: 88: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:12,182 INFO L290 TraceCheckUtils]: 87: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:12,182 INFO L272 TraceCheckUtils]: 86: Hoare triple {14052#(<= 1 (div (div main_~p~0 2) 2))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:12,183 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {13910#true} {14052#(<= 1 (div (div main_~p~0 2) 2))} #86#return; {14052#(<= 1 (div (div main_~p~0 2) 2))} is VALID [2022-04-08 13:28:12,183 INFO L290 TraceCheckUtils]: 84: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:12,183 INFO L290 TraceCheckUtils]: 83: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:12,183 INFO L290 TraceCheckUtils]: 82: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:12,183 INFO L272 TraceCheckUtils]: 81: Hoare triple {14052#(<= 1 (div (div main_~p~0 2) 2))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:12,184 INFO L290 TraceCheckUtils]: 80: Hoare triple {14052#(<= 1 (div (div main_~p~0 2) 2))} assume !false; {14052#(<= 1 (div (div main_~p~0 2) 2))} is VALID [2022-04-08 13:28:12,184 INFO L290 TraceCheckUtils]: 79: Hoare triple {14052#(<= 1 (div (div main_~p~0 2) 2))} assume !(~r~0 >= ~d~0); {14052#(<= 1 (div (div main_~p~0 2) 2))} is VALID [2022-04-08 13:28:12,184 INFO L284 TraceCheckUtils]: 78: Hoare quadruple {13910#true} {14052#(<= 1 (div (div main_~p~0 2) 2))} #84#return; {14052#(<= 1 (div (div main_~p~0 2) 2))} is VALID [2022-04-08 13:28:12,184 INFO L290 TraceCheckUtils]: 77: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:12,184 INFO L290 TraceCheckUtils]: 76: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:12,184 INFO L290 TraceCheckUtils]: 75: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:12,185 INFO L272 TraceCheckUtils]: 74: Hoare triple {14052#(<= 1 (div (div main_~p~0 2) 2))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:12,185 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {13910#true} {14052#(<= 1 (div (div main_~p~0 2) 2))} #82#return; {14052#(<= 1 (div (div main_~p~0 2) 2))} is VALID [2022-04-08 13:28:12,185 INFO L290 TraceCheckUtils]: 72: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:12,185 INFO L290 TraceCheckUtils]: 71: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:12,185 INFO L290 TraceCheckUtils]: 70: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:12,185 INFO L272 TraceCheckUtils]: 69: Hoare triple {14052#(<= 1 (div (div main_~p~0 2) 2))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:12,186 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {13910#true} {14052#(<= 1 (div (div main_~p~0 2) 2))} #80#return; {14052#(<= 1 (div (div main_~p~0 2) 2))} is VALID [2022-04-08 13:28:12,186 INFO L290 TraceCheckUtils]: 67: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:12,186 INFO L290 TraceCheckUtils]: 66: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:12,186 INFO L290 TraceCheckUtils]: 65: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:12,186 INFO L272 TraceCheckUtils]: 64: Hoare triple {14052#(<= 1 (div (div main_~p~0 2) 2))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:12,186 INFO L290 TraceCheckUtils]: 63: Hoare triple {14052#(<= 1 (div (div main_~p~0 2) 2))} assume !false; {14052#(<= 1 (div (div main_~p~0 2) 2))} is VALID [2022-04-08 13:28:12,187 INFO L290 TraceCheckUtils]: 62: Hoare triple {14000#(<= 1 (div main_~p~0 2))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {14052#(<= 1 (div (div main_~p~0 2) 2))} is VALID [2022-04-08 13:28:12,188 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {13910#true} {14000#(<= 1 (div main_~p~0 2))} #84#return; {14000#(<= 1 (div main_~p~0 2))} is VALID [2022-04-08 13:28:12,188 INFO L290 TraceCheckUtils]: 60: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:12,188 INFO L290 TraceCheckUtils]: 59: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:12,188 INFO L290 TraceCheckUtils]: 58: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:12,188 INFO L272 TraceCheckUtils]: 57: Hoare triple {14000#(<= 1 (div main_~p~0 2))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:12,188 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {13910#true} {14000#(<= 1 (div main_~p~0 2))} #82#return; {14000#(<= 1 (div main_~p~0 2))} is VALID [2022-04-08 13:28:12,188 INFO L290 TraceCheckUtils]: 55: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:12,188 INFO L290 TraceCheckUtils]: 54: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:12,189 INFO L290 TraceCheckUtils]: 53: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:12,189 INFO L272 TraceCheckUtils]: 52: Hoare triple {14000#(<= 1 (div main_~p~0 2))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:12,189 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {13910#true} {14000#(<= 1 (div main_~p~0 2))} #80#return; {14000#(<= 1 (div main_~p~0 2))} is VALID [2022-04-08 13:28:12,189 INFO L290 TraceCheckUtils]: 50: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:12,189 INFO L290 TraceCheckUtils]: 49: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:12,189 INFO L290 TraceCheckUtils]: 48: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:12,189 INFO L272 TraceCheckUtils]: 47: Hoare triple {14000#(<= 1 (div main_~p~0 2))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:12,189 INFO L290 TraceCheckUtils]: 46: Hoare triple {14000#(<= 1 (div main_~p~0 2))} assume !false; {14000#(<= 1 (div main_~p~0 2))} is VALID [2022-04-08 13:28:12,190 INFO L290 TraceCheckUtils]: 45: Hoare triple {13948#(<= 1 main_~p~0)} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {14000#(<= 1 (div main_~p~0 2))} is VALID [2022-04-08 13:28:12,191 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {13910#true} {13948#(<= 1 main_~p~0)} #84#return; {13948#(<= 1 main_~p~0)} is VALID [2022-04-08 13:28:12,191 INFO L290 TraceCheckUtils]: 43: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:12,191 INFO L290 TraceCheckUtils]: 42: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:12,191 INFO L290 TraceCheckUtils]: 41: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:12,191 INFO L272 TraceCheckUtils]: 40: Hoare triple {13948#(<= 1 main_~p~0)} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:12,191 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {13910#true} {13948#(<= 1 main_~p~0)} #82#return; {13948#(<= 1 main_~p~0)} is VALID [2022-04-08 13:28:12,191 INFO L290 TraceCheckUtils]: 38: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:12,191 INFO L290 TraceCheckUtils]: 37: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:12,191 INFO L290 TraceCheckUtils]: 36: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:12,191 INFO L272 TraceCheckUtils]: 35: Hoare triple {13948#(<= 1 main_~p~0)} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:12,192 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {13910#true} {13948#(<= 1 main_~p~0)} #80#return; {13948#(<= 1 main_~p~0)} is VALID [2022-04-08 13:28:12,192 INFO L290 TraceCheckUtils]: 33: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:12,192 INFO L290 TraceCheckUtils]: 32: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:12,192 INFO L290 TraceCheckUtils]: 31: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:12,192 INFO L272 TraceCheckUtils]: 30: Hoare triple {13948#(<= 1 main_~p~0)} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:12,192 INFO L290 TraceCheckUtils]: 29: Hoare triple {13948#(<= 1 main_~p~0)} assume !false; {13948#(<= 1 main_~p~0)} is VALID [2022-04-08 13:28:12,193 INFO L290 TraceCheckUtils]: 28: Hoare triple {13948#(<= 1 main_~p~0)} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {13948#(<= 1 main_~p~0)} is VALID [2022-04-08 13:28:12,193 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {13910#true} {13948#(<= 1 main_~p~0)} #84#return; {13948#(<= 1 main_~p~0)} is VALID [2022-04-08 13:28:12,193 INFO L290 TraceCheckUtils]: 26: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:12,193 INFO L290 TraceCheckUtils]: 25: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:12,193 INFO L290 TraceCheckUtils]: 24: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:12,193 INFO L272 TraceCheckUtils]: 23: Hoare triple {13948#(<= 1 main_~p~0)} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:12,194 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {13910#true} {13948#(<= 1 main_~p~0)} #82#return; {13948#(<= 1 main_~p~0)} is VALID [2022-04-08 13:28:12,194 INFO L290 TraceCheckUtils]: 21: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:12,194 INFO L290 TraceCheckUtils]: 20: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:12,194 INFO L290 TraceCheckUtils]: 19: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:12,194 INFO L272 TraceCheckUtils]: 18: Hoare triple {13948#(<= 1 main_~p~0)} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:12,194 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {13910#true} {13948#(<= 1 main_~p~0)} #80#return; {13948#(<= 1 main_~p~0)} is VALID [2022-04-08 13:28:12,194 INFO L290 TraceCheckUtils]: 16: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:12,194 INFO L290 TraceCheckUtils]: 15: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:12,194 INFO L290 TraceCheckUtils]: 14: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:12,194 INFO L272 TraceCheckUtils]: 13: Hoare triple {13948#(<= 1 main_~p~0)} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:12,195 INFO L290 TraceCheckUtils]: 12: Hoare triple {13948#(<= 1 main_~p~0)} assume !false; {13948#(<= 1 main_~p~0)} is VALID [2022-04-08 13:28:12,195 INFO L290 TraceCheckUtils]: 11: Hoare triple {13910#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {13948#(<= 1 main_~p~0)} is VALID [2022-04-08 13:28:12,195 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {13910#true} {13910#true} #78#return; {13910#true} is VALID [2022-04-08 13:28:12,195 INFO L290 TraceCheckUtils]: 9: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:12,195 INFO L290 TraceCheckUtils]: 8: Hoare triple {13910#true} assume !(0 == ~cond); {13910#true} is VALID [2022-04-08 13:28:12,195 INFO L290 TraceCheckUtils]: 7: Hoare triple {13910#true} ~cond := #in~cond; {13910#true} is VALID [2022-04-08 13:28:12,195 INFO L272 TraceCheckUtils]: 6: Hoare triple {13910#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {13910#true} is VALID [2022-04-08 13:28:12,195 INFO L290 TraceCheckUtils]: 5: Hoare triple {13910#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {13910#true} is VALID [2022-04-08 13:28:12,195 INFO L272 TraceCheckUtils]: 4: Hoare triple {13910#true} call #t~ret5 := main(); {13910#true} is VALID [2022-04-08 13:28:12,195 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {13910#true} {13910#true} #94#return; {13910#true} is VALID [2022-04-08 13:28:12,195 INFO L290 TraceCheckUtils]: 2: Hoare triple {13910#true} assume true; {13910#true} is VALID [2022-04-08 13:28:12,196 INFO L290 TraceCheckUtils]: 1: Hoare triple {13910#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {13910#true} is VALID [2022-04-08 13:28:12,196 INFO L272 TraceCheckUtils]: 0: Hoare triple {13910#true} call ULTIMATE.init(); {13910#true} is VALID [2022-04-08 13:28:12,196 INFO L134 CoverageAnalysis]: Checked inductivity of 546 backedges. 57 proven. 4 refuted. 0 times theorem prover too weak. 485 trivial. 0 not checked. [2022-04-08 13:28:12,196 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-08 13:28:12,196 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [614031993] [2022-04-08 13:28:12,196 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-08 13:28:12,196 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [128005726] [2022-04-08 13:28:12,196 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [128005726] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-08 13:28:12,196 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-08 13:28:12,196 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [6, 5] total 6 [2022-04-08 13:28:12,197 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-08 13:28:12,197 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [1623895039] [2022-04-08 13:28:12,197 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [1623895039] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:28:12,197 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:28:12,197 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [6] imperfect sequences [] total 6 [2022-04-08 13:28:12,197 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [490885203] [2022-04-08 13:28:12,197 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-08 13:28:12,197 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 4.333333333333333) internal successors, (26), 6 states have internal predecessors, (26), 6 states have call successors, (20), 2 states have call predecessors, (20), 1 states have return successors, (18), 5 states have call predecessors, (18), 5 states have call successors, (18) Word has length 109 [2022-04-08 13:28:12,197 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-08 13:28:12,197 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 6 states, 6 states have (on average 4.333333333333333) internal successors, (26), 6 states have internal predecessors, (26), 6 states have call successors, (20), 2 states have call predecessors, (20), 1 states have return successors, (18), 5 states have call predecessors, (18), 5 states have call successors, (18) [2022-04-08 13:28:12,247 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 64 edges. 64 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:28:12,248 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 6 states [2022-04-08 13:28:12,248 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-08 13:28:12,248 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 6 interpolants. [2022-04-08 13:28:12,248 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=15, Invalid=15, Unknown=0, NotChecked=0, Total=30 [2022-04-08 13:28:12,248 INFO L87 Difference]: Start difference. First operand 107 states and 117 transitions. Second operand has 6 states, 6 states have (on average 4.333333333333333) internal successors, (26), 6 states have internal predecessors, (26), 6 states have call successors, (20), 2 states have call predecessors, (20), 1 states have return successors, (18), 5 states have call predecessors, (18), 5 states have call successors, (18) [2022-04-08 13:28:12,610 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:28:12,610 INFO L93 Difference]: Finished difference Result 128 states and 148 transitions. [2022-04-08 13:28:12,610 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 6 states. [2022-04-08 13:28:12,611 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 4.333333333333333) internal successors, (26), 6 states have internal predecessors, (26), 6 states have call successors, (20), 2 states have call predecessors, (20), 1 states have return successors, (18), 5 states have call predecessors, (18), 5 states have call successors, (18) Word has length 109 [2022-04-08 13:28:12,611 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-08 13:28:12,611 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 4.333333333333333) internal successors, (26), 6 states have internal predecessors, (26), 6 states have call successors, (20), 2 states have call predecessors, (20), 1 states have return successors, (18), 5 states have call predecessors, (18), 5 states have call successors, (18) [2022-04-08 13:28:12,612 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 6 states to 6 states and 93 transitions. [2022-04-08 13:28:12,612 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 4.333333333333333) internal successors, (26), 6 states have internal predecessors, (26), 6 states have call successors, (20), 2 states have call predecessors, (20), 1 states have return successors, (18), 5 states have call predecessors, (18), 5 states have call successors, (18) [2022-04-08 13:28:12,613 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 6 states to 6 states and 93 transitions. [2022-04-08 13:28:12,613 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 6 states and 93 transitions. [2022-04-08 13:28:12,690 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 93 edges. 93 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:28:12,692 INFO L225 Difference]: With dead ends: 128 [2022-04-08 13:28:12,692 INFO L226 Difference]: Without dead ends: 120 [2022-04-08 13:28:12,692 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 217 GetRequests, 208 SyntacticMatches, 5 SemanticMatches, 4 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 9 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=15, Invalid=15, Unknown=0, NotChecked=0, Total=30 [2022-04-08 13:28:12,693 INFO L913 BasicCegarLoop]: 61 mSDtfsCounter, 12 mSDsluCounter, 89 mSDsCounter, 0 mSdLazyCounter, 65 mSolverCounterSat, 10 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.1s Time, 0 mProtectedPredicate, 0 mProtectedAction, 17 SdHoareTripleChecker+Valid, 150 SdHoareTripleChecker+Invalid, 75 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 10 IncrementalHoareTripleChecker+Valid, 65 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.1s IncrementalHoareTripleChecker+Time [2022-04-08 13:28:12,693 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [17 Valid, 150 Invalid, 75 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [10 Valid, 65 Invalid, 0 Unknown, 0 Unchecked, 0.1s Time] [2022-04-08 13:28:12,693 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 120 states. [2022-04-08 13:28:12,806 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 120 to 120. [2022-04-08 13:28:12,807 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-08 13:28:12,807 INFO L82 GeneralOperation]: Start isEquivalent. First operand 120 states. Second operand has 120 states, 74 states have (on average 1.0945945945945945) internal successors, (81), 75 states have internal predecessors, (81), 29 states have call successors, (29), 17 states have call predecessors, (29), 16 states have return successors, (27), 27 states have call predecessors, (27), 27 states have call successors, (27) [2022-04-08 13:28:12,807 INFO L74 IsIncluded]: Start isIncluded. First operand 120 states. Second operand has 120 states, 74 states have (on average 1.0945945945945945) internal successors, (81), 75 states have internal predecessors, (81), 29 states have call successors, (29), 17 states have call predecessors, (29), 16 states have return successors, (27), 27 states have call predecessors, (27), 27 states have call successors, (27) [2022-04-08 13:28:12,807 INFO L87 Difference]: Start difference. First operand 120 states. Second operand has 120 states, 74 states have (on average 1.0945945945945945) internal successors, (81), 75 states have internal predecessors, (81), 29 states have call successors, (29), 17 states have call predecessors, (29), 16 states have return successors, (27), 27 states have call predecessors, (27), 27 states have call successors, (27) [2022-04-08 13:28:12,814 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:28:12,814 INFO L93 Difference]: Finished difference Result 120 states and 137 transitions. [2022-04-08 13:28:12,814 INFO L276 IsEmpty]: Start isEmpty. Operand 120 states and 137 transitions. [2022-04-08 13:28:12,814 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:28:12,814 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:28:12,814 INFO L74 IsIncluded]: Start isIncluded. First operand has 120 states, 74 states have (on average 1.0945945945945945) internal successors, (81), 75 states have internal predecessors, (81), 29 states have call successors, (29), 17 states have call predecessors, (29), 16 states have return successors, (27), 27 states have call predecessors, (27), 27 states have call successors, (27) Second operand 120 states. [2022-04-08 13:28:12,815 INFO L87 Difference]: Start difference. First operand has 120 states, 74 states have (on average 1.0945945945945945) internal successors, (81), 75 states have internal predecessors, (81), 29 states have call successors, (29), 17 states have call predecessors, (29), 16 states have return successors, (27), 27 states have call predecessors, (27), 27 states have call successors, (27) Second operand 120 states. [2022-04-08 13:28:12,816 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:28:12,816 INFO L93 Difference]: Finished difference Result 120 states and 137 transitions. [2022-04-08 13:28:12,816 INFO L276 IsEmpty]: Start isEmpty. Operand 120 states and 137 transitions. [2022-04-08 13:28:12,817 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:28:12,817 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:28:12,817 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-08 13:28:12,817 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-08 13:28:12,817 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 120 states, 74 states have (on average 1.0945945945945945) internal successors, (81), 75 states have internal predecessors, (81), 29 states have call successors, (29), 17 states have call predecessors, (29), 16 states have return successors, (27), 27 states have call predecessors, (27), 27 states have call successors, (27) [2022-04-08 13:28:12,818 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 120 states to 120 states and 137 transitions. [2022-04-08 13:28:12,819 INFO L78 Accepts]: Start accepts. Automaton has 120 states and 137 transitions. Word has length 109 [2022-04-08 13:28:12,819 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-08 13:28:12,819 INFO L478 AbstractCegarLoop]: Abstraction has 120 states and 137 transitions. [2022-04-08 13:28:12,819 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 6 states, 6 states have (on average 4.333333333333333) internal successors, (26), 6 states have internal predecessors, (26), 6 states have call successors, (20), 2 states have call predecessors, (20), 1 states have return successors, (18), 5 states have call predecessors, (18), 5 states have call successors, (18) [2022-04-08 13:28:12,819 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 120 states and 137 transitions. [2022-04-08 13:28:13,013 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 137 edges. 137 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:28:13,013 INFO L276 IsEmpty]: Start isEmpty. Operand 120 states and 137 transitions. [2022-04-08 13:28:13,013 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 112 [2022-04-08 13:28:13,013 INFO L491 BasicCegarLoop]: Found error trace [2022-04-08 13:28:13,014 INFO L499 BasicCegarLoop]: trace histogram [17, 16, 16, 4, 4, 4, 4, 4, 4, 4, 3, 3, 3, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-08 13:28:13,042 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (14)] Forceful destruction successful, exit code 0 [2022-04-08 13:28:13,214 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 14 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable15 [2022-04-08 13:28:13,214 INFO L403 AbstractCegarLoop]: === Iteration 17 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-08 13:28:13,214 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-08 13:28:13,215 INFO L85 PathProgramCache]: Analyzing trace with hash -76721736, now seen corresponding path program 13 times [2022-04-08 13:28:13,215 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-08 13:28:13,215 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [321147519] [2022-04-08 13:28:15,337 INFO L97 AcceleratorQvasr]: Qvasr could not accelerate loop because java.lang.UnsupportedOperationException: Cannot deal with arrays. [2022-04-08 13:28:15,338 INFO L274 tedInterpolationCore]: Could not compute an accelerate. [2022-04-08 13:28:15,338 INFO L85 PathProgramCache]: Analyzing trace with hash -76721736, now seen corresponding path program 14 times [2022-04-08 13:28:15,338 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-08 13:28:15,338 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [385661937] [2022-04-08 13:28:15,338 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-08 13:28:15,338 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-08 13:28:15,347 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-08 13:28:15,347 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1322659176] [2022-04-08 13:28:15,347 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-08 13:28:15,347 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:28:15,347 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-08 13:28:15,348 INFO L229 MonitoredProcess]: Starting monitored process 15 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-08 13:28:15,349 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (15)] Waiting until timeout for monitored process [2022-04-08 13:28:15,397 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-08 13:28:15,397 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-08 13:28:15,398 INFO L263 TraceCheckSpWp]: Trace formula consists of 258 conjuncts, 43 conjunts are in the unsatisfiable core [2022-04-08 13:28:15,415 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:28:15,417 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-08 13:28:16,078 INFO L272 TraceCheckUtils]: 0: Hoare triple {15305#true} call ULTIMATE.init(); {15305#true} is VALID [2022-04-08 13:28:16,079 INFO L290 TraceCheckUtils]: 1: Hoare triple {15305#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {15305#true} is VALID [2022-04-08 13:28:16,079 INFO L290 TraceCheckUtils]: 2: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:16,079 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {15305#true} {15305#true} #94#return; {15305#true} is VALID [2022-04-08 13:28:16,079 INFO L272 TraceCheckUtils]: 4: Hoare triple {15305#true} call #t~ret5 := main(); {15305#true} is VALID [2022-04-08 13:28:16,079 INFO L290 TraceCheckUtils]: 5: Hoare triple {15305#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {15305#true} is VALID [2022-04-08 13:28:16,079 INFO L272 TraceCheckUtils]: 6: Hoare triple {15305#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:16,079 INFO L290 TraceCheckUtils]: 7: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:16,079 INFO L290 TraceCheckUtils]: 8: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:16,079 INFO L290 TraceCheckUtils]: 9: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:16,079 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {15305#true} {15305#true} #78#return; {15305#true} is VALID [2022-04-08 13:28:16,079 INFO L290 TraceCheckUtils]: 11: Hoare triple {15305#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {15343#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:28:16,080 INFO L290 TraceCheckUtils]: 12: Hoare triple {15343#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !false; {15343#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:28:16,080 INFO L272 TraceCheckUtils]: 13: Hoare triple {15343#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:16,080 INFO L290 TraceCheckUtils]: 14: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:16,080 INFO L290 TraceCheckUtils]: 15: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:16,080 INFO L290 TraceCheckUtils]: 16: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:16,081 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {15305#true} {15343#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #80#return; {15343#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:28:16,081 INFO L272 TraceCheckUtils]: 18: Hoare triple {15343#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:16,081 INFO L290 TraceCheckUtils]: 19: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:16,081 INFO L290 TraceCheckUtils]: 20: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:16,081 INFO L290 TraceCheckUtils]: 21: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:16,081 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {15305#true} {15343#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #82#return; {15343#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:28:16,081 INFO L272 TraceCheckUtils]: 23: Hoare triple {15343#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:16,081 INFO L290 TraceCheckUtils]: 24: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:16,081 INFO L290 TraceCheckUtils]: 25: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:16,082 INFO L290 TraceCheckUtils]: 26: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:16,082 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {15305#true} {15343#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #84#return; {15343#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:28:16,082 INFO L290 TraceCheckUtils]: 28: Hoare triple {15343#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {15395#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:28:16,083 INFO L290 TraceCheckUtils]: 29: Hoare triple {15395#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} assume !false; {15395#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:28:16,083 INFO L272 TraceCheckUtils]: 30: Hoare triple {15395#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:16,083 INFO L290 TraceCheckUtils]: 31: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:16,083 INFO L290 TraceCheckUtils]: 32: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:16,083 INFO L290 TraceCheckUtils]: 33: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:16,083 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {15305#true} {15395#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #80#return; {15395#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:28:16,084 INFO L272 TraceCheckUtils]: 35: Hoare triple {15395#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:16,084 INFO L290 TraceCheckUtils]: 36: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:16,084 INFO L290 TraceCheckUtils]: 37: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:16,084 INFO L290 TraceCheckUtils]: 38: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:16,084 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {15305#true} {15395#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #82#return; {15395#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:28:16,084 INFO L272 TraceCheckUtils]: 40: Hoare triple {15395#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:16,084 INFO L290 TraceCheckUtils]: 41: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:16,084 INFO L290 TraceCheckUtils]: 42: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:16,084 INFO L290 TraceCheckUtils]: 43: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:16,085 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {15305#true} {15395#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #84#return; {15395#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:28:16,085 INFO L290 TraceCheckUtils]: 45: Hoare triple {15395#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {15447#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:28:16,086 INFO L290 TraceCheckUtils]: 46: Hoare triple {15447#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} assume !false; {15447#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:28:16,086 INFO L272 TraceCheckUtils]: 47: Hoare triple {15447#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:16,086 INFO L290 TraceCheckUtils]: 48: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:16,086 INFO L290 TraceCheckUtils]: 49: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:16,086 INFO L290 TraceCheckUtils]: 50: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:16,086 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {15305#true} {15447#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} #80#return; {15447#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:28:16,086 INFO L272 TraceCheckUtils]: 52: Hoare triple {15447#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:16,086 INFO L290 TraceCheckUtils]: 53: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:16,086 INFO L290 TraceCheckUtils]: 54: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:16,087 INFO L290 TraceCheckUtils]: 55: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:16,087 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {15305#true} {15447#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} #82#return; {15447#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:28:16,087 INFO L272 TraceCheckUtils]: 57: Hoare triple {15447#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:16,087 INFO L290 TraceCheckUtils]: 58: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:16,087 INFO L290 TraceCheckUtils]: 59: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:16,087 INFO L290 TraceCheckUtils]: 60: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:16,088 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {15305#true} {15447#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} #84#return; {15447#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:28:16,088 INFO L290 TraceCheckUtils]: 62: Hoare triple {15447#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:28:16,088 INFO L290 TraceCheckUtils]: 63: Hoare triple {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} assume !false; {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:28:16,089 INFO L272 TraceCheckUtils]: 64: Hoare triple {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:16,089 INFO L290 TraceCheckUtils]: 65: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:16,089 INFO L290 TraceCheckUtils]: 66: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:16,089 INFO L290 TraceCheckUtils]: 67: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:16,089 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {15305#true} {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} #80#return; {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:28:16,089 INFO L272 TraceCheckUtils]: 69: Hoare triple {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:16,089 INFO L290 TraceCheckUtils]: 70: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:16,089 INFO L290 TraceCheckUtils]: 71: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:16,089 INFO L290 TraceCheckUtils]: 72: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:16,090 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {15305#true} {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} #82#return; {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:28:16,090 INFO L272 TraceCheckUtils]: 74: Hoare triple {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:16,090 INFO L290 TraceCheckUtils]: 75: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:16,090 INFO L290 TraceCheckUtils]: 76: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:16,090 INFO L290 TraceCheckUtils]: 77: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:16,090 INFO L284 TraceCheckUtils]: 78: Hoare quadruple {15305#true} {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} #84#return; {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:28:16,091 INFO L290 TraceCheckUtils]: 79: Hoare triple {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} assume !(~r~0 >= ~d~0); {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:28:16,091 INFO L290 TraceCheckUtils]: 80: Hoare triple {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} assume !false; {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:28:16,091 INFO L272 TraceCheckUtils]: 81: Hoare triple {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:16,091 INFO L290 TraceCheckUtils]: 82: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:16,091 INFO L290 TraceCheckUtils]: 83: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:16,091 INFO L290 TraceCheckUtils]: 84: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:16,092 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {15305#true} {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} #86#return; {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:28:16,092 INFO L272 TraceCheckUtils]: 86: Hoare triple {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:16,092 INFO L290 TraceCheckUtils]: 87: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:16,092 INFO L290 TraceCheckUtils]: 88: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:16,092 INFO L290 TraceCheckUtils]: 89: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:16,093 INFO L284 TraceCheckUtils]: 90: Hoare quadruple {15305#true} {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} #88#return; {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:28:16,093 INFO L290 TraceCheckUtils]: 91: Hoare triple {15499#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {15447#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:28:16,094 INFO L290 TraceCheckUtils]: 92: Hoare triple {15447#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {15590#(and (= main_~q~0 main_~p~0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} is VALID [2022-04-08 13:28:16,094 INFO L290 TraceCheckUtils]: 93: Hoare triple {15590#(and (= main_~q~0 main_~p~0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} assume !false; {15590#(and (= main_~q~0 main_~p~0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} is VALID [2022-04-08 13:28:16,094 INFO L272 TraceCheckUtils]: 94: Hoare triple {15590#(and (= main_~q~0 main_~p~0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:16,094 INFO L290 TraceCheckUtils]: 95: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:16,094 INFO L290 TraceCheckUtils]: 96: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:16,094 INFO L290 TraceCheckUtils]: 97: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:16,095 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {15305#true} {15590#(and (= main_~q~0 main_~p~0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} #86#return; {15590#(and (= main_~q~0 main_~p~0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} is VALID [2022-04-08 13:28:16,095 INFO L272 TraceCheckUtils]: 99: Hoare triple {15590#(and (= main_~q~0 main_~p~0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:16,095 INFO L290 TraceCheckUtils]: 100: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:16,095 INFO L290 TraceCheckUtils]: 101: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:16,095 INFO L290 TraceCheckUtils]: 102: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:16,095 INFO L284 TraceCheckUtils]: 103: Hoare quadruple {15305#true} {15590#(and (= main_~q~0 main_~p~0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} #88#return; {15590#(and (= main_~q~0 main_~p~0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} is VALID [2022-04-08 13:28:16,096 INFO L290 TraceCheckUtils]: 104: Hoare triple {15590#(and (= main_~q~0 main_~p~0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {15627#(and (= main_~p~0 (div main_~q~0 2)) (= (div (+ main_~A~0 (* (- 1) main_~r~0)) 2) main_~d~0) (= (+ main_~A~0 (* (- 1) main_~r~0)) (* main_~B~0 4)) (= main_~B~0 1) (= main_~q~0 4))} is VALID [2022-04-08 13:28:16,097 INFO L290 TraceCheckUtils]: 105: Hoare triple {15627#(and (= main_~p~0 (div main_~q~0 2)) (= (div (+ main_~A~0 (* (- 1) main_~r~0)) 2) main_~d~0) (= (+ main_~A~0 (* (- 1) main_~r~0)) (* main_~B~0 4)) (= main_~B~0 1) (= main_~q~0 4))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {15631#(and (= 2 (+ main_~q~0 (- 4))) (= main_~B~0 1) (= (+ main_~A~0 (* main_~B~0 (- 4)) (* (- 1) main_~r~0)) (div (* main_~B~0 4) 2)))} is VALID [2022-04-08 13:28:16,097 INFO L290 TraceCheckUtils]: 106: Hoare triple {15631#(and (= 2 (+ main_~q~0 (- 4))) (= main_~B~0 1) (= (+ main_~A~0 (* main_~B~0 (- 4)) (* (- 1) main_~r~0)) (div (* main_~B~0 4) 2)))} assume !false; {15631#(and (= 2 (+ main_~q~0 (- 4))) (= main_~B~0 1) (= (+ main_~A~0 (* main_~B~0 (- 4)) (* (- 1) main_~r~0)) (div (* main_~B~0 4) 2)))} is VALID [2022-04-08 13:28:16,098 INFO L272 TraceCheckUtils]: 107: Hoare triple {15631#(and (= 2 (+ main_~q~0 (- 4))) (= main_~B~0 1) (= (+ main_~A~0 (* main_~B~0 (- 4)) (* (- 1) main_~r~0)) (div (* main_~B~0 4) 2)))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {15638#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:28:16,098 INFO L290 TraceCheckUtils]: 108: Hoare triple {15638#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {15642#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:28:16,098 INFO L290 TraceCheckUtils]: 109: Hoare triple {15642#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {15306#false} is VALID [2022-04-08 13:28:16,098 INFO L290 TraceCheckUtils]: 110: Hoare triple {15306#false} assume !false; {15306#false} is VALID [2022-04-08 13:28:16,099 INFO L134 CoverageAnalysis]: Checked inductivity of 551 backedges. 32 proven. 39 refuted. 0 times theorem prover too weak. 480 trivial. 0 not checked. [2022-04-08 13:28:16,099 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-08 13:28:48,530 INFO L290 TraceCheckUtils]: 110: Hoare triple {15306#false} assume !false; {15306#false} is VALID [2022-04-08 13:28:48,530 INFO L290 TraceCheckUtils]: 109: Hoare triple {15642#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {15306#false} is VALID [2022-04-08 13:28:48,531 INFO L290 TraceCheckUtils]: 108: Hoare triple {15638#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {15642#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:28:48,531 INFO L272 TraceCheckUtils]: 107: Hoare triple {15658#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {15638#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:28:48,531 INFO L290 TraceCheckUtils]: 106: Hoare triple {15658#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} assume !false; {15658#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:28:48,549 INFO L290 TraceCheckUtils]: 105: Hoare triple {15665#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {15658#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:28:48,569 INFO L290 TraceCheckUtils]: 104: Hoare triple {15669#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {15665#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} is VALID [2022-04-08 13:28:48,570 INFO L284 TraceCheckUtils]: 103: Hoare quadruple {15305#true} {15669#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} #88#return; {15669#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:28:48,570 INFO L290 TraceCheckUtils]: 102: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:48,570 INFO L290 TraceCheckUtils]: 101: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:48,570 INFO L290 TraceCheckUtils]: 100: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:48,570 INFO L272 TraceCheckUtils]: 99: Hoare triple {15669#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:48,571 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {15305#true} {15669#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} #86#return; {15669#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:28:48,571 INFO L290 TraceCheckUtils]: 97: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:48,571 INFO L290 TraceCheckUtils]: 96: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:48,571 INFO L290 TraceCheckUtils]: 95: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:48,571 INFO L272 TraceCheckUtils]: 94: Hoare triple {15669#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:48,572 INFO L290 TraceCheckUtils]: 93: Hoare triple {15669#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} assume !false; {15669#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:28:48,597 INFO L290 TraceCheckUtils]: 92: Hoare triple {15706#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {15669#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:28:48,919 INFO L290 TraceCheckUtils]: 91: Hoare triple {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {15706#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} is VALID [2022-04-08 13:28:48,920 INFO L284 TraceCheckUtils]: 90: Hoare quadruple {15305#true} {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} #88#return; {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:28:48,920 INFO L290 TraceCheckUtils]: 89: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:48,920 INFO L290 TraceCheckUtils]: 88: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:48,920 INFO L290 TraceCheckUtils]: 87: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:48,920 INFO L272 TraceCheckUtils]: 86: Hoare triple {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:48,921 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {15305#true} {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} #86#return; {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:28:48,921 INFO L290 TraceCheckUtils]: 84: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:48,921 INFO L290 TraceCheckUtils]: 83: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:48,921 INFO L290 TraceCheckUtils]: 82: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:48,921 INFO L272 TraceCheckUtils]: 81: Hoare triple {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:48,925 INFO L290 TraceCheckUtils]: 80: Hoare triple {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} assume !false; {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:28:48,928 INFO L290 TraceCheckUtils]: 79: Hoare triple {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} assume !(~r~0 >= ~d~0); {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:28:48,929 INFO L284 TraceCheckUtils]: 78: Hoare quadruple {15305#true} {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} #84#return; {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:28:48,929 INFO L290 TraceCheckUtils]: 77: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:48,929 INFO L290 TraceCheckUtils]: 76: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:48,929 INFO L290 TraceCheckUtils]: 75: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:48,930 INFO L272 TraceCheckUtils]: 74: Hoare triple {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:48,930 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {15305#true} {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} #82#return; {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:28:48,930 INFO L290 TraceCheckUtils]: 72: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:48,930 INFO L290 TraceCheckUtils]: 71: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:48,930 INFO L290 TraceCheckUtils]: 70: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:48,931 INFO L272 TraceCheckUtils]: 69: Hoare triple {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:48,931 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {15305#true} {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} #80#return; {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:28:48,931 INFO L290 TraceCheckUtils]: 67: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:48,931 INFO L290 TraceCheckUtils]: 66: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:48,931 INFO L290 TraceCheckUtils]: 65: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:48,932 INFO L272 TraceCheckUtils]: 64: Hoare triple {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:48,935 INFO L290 TraceCheckUtils]: 63: Hoare triple {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} assume !false; {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:28:49,207 INFO L290 TraceCheckUtils]: 62: Hoare triple {15706#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {15710#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:28:49,207 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {15305#true} {15706#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} #84#return; {15706#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} is VALID [2022-04-08 13:28:49,207 INFO L290 TraceCheckUtils]: 60: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:49,208 INFO L290 TraceCheckUtils]: 59: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:49,208 INFO L290 TraceCheckUtils]: 58: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:49,208 INFO L272 TraceCheckUtils]: 57: Hoare triple {15706#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:49,208 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {15305#true} {15706#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} #82#return; {15706#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} is VALID [2022-04-08 13:28:49,208 INFO L290 TraceCheckUtils]: 55: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:49,208 INFO L290 TraceCheckUtils]: 54: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:49,208 INFO L290 TraceCheckUtils]: 53: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:49,208 INFO L272 TraceCheckUtils]: 52: Hoare triple {15706#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:49,209 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {15305#true} {15706#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} #80#return; {15706#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} is VALID [2022-04-08 13:28:49,209 INFO L290 TraceCheckUtils]: 50: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:49,209 INFO L290 TraceCheckUtils]: 49: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:49,209 INFO L290 TraceCheckUtils]: 48: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:49,209 INFO L272 TraceCheckUtils]: 47: Hoare triple {15706#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:49,210 INFO L290 TraceCheckUtils]: 46: Hoare triple {15706#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} assume !false; {15706#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} is VALID [2022-04-08 13:28:49,231 INFO L290 TraceCheckUtils]: 45: Hoare triple {15849#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {15706#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} is VALID [2022-04-08 13:28:49,232 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {15305#true} {15849#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} #84#return; {15849#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} is VALID [2022-04-08 13:28:49,232 INFO L290 TraceCheckUtils]: 43: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:49,232 INFO L290 TraceCheckUtils]: 42: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:49,232 INFO L290 TraceCheckUtils]: 41: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:49,232 INFO L272 TraceCheckUtils]: 40: Hoare triple {15849#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:49,232 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {15305#true} {15849#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} #82#return; {15849#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} is VALID [2022-04-08 13:28:49,232 INFO L290 TraceCheckUtils]: 38: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:49,232 INFO L290 TraceCheckUtils]: 37: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:49,232 INFO L290 TraceCheckUtils]: 36: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:49,232 INFO L272 TraceCheckUtils]: 35: Hoare triple {15849#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:49,233 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {15305#true} {15849#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} #80#return; {15849#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} is VALID [2022-04-08 13:28:49,233 INFO L290 TraceCheckUtils]: 33: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:49,233 INFO L290 TraceCheckUtils]: 32: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:49,233 INFO L290 TraceCheckUtils]: 31: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:49,233 INFO L272 TraceCheckUtils]: 30: Hoare triple {15849#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:49,234 INFO L290 TraceCheckUtils]: 29: Hoare triple {15849#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} assume !false; {15849#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} is VALID [2022-04-08 13:28:49,236 INFO L290 TraceCheckUtils]: 28: Hoare triple {15901#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* 3 (* (* main_~p~0 2) main_~B~0))) (+ main_~A~0 (* main_~d~0 6)))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {15849#(= (+ (* (* main_~B~0 main_~p~0) 3) (* main_~B~0 main_~q~0) main_~r~0) (+ main_~A~0 (* main_~d~0 3)))} is VALID [2022-04-08 13:28:49,237 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {15305#true} {15901#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* 3 (* (* main_~p~0 2) main_~B~0))) (+ main_~A~0 (* main_~d~0 6)))} #84#return; {15901#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* 3 (* (* main_~p~0 2) main_~B~0))) (+ main_~A~0 (* main_~d~0 6)))} is VALID [2022-04-08 13:28:49,237 INFO L290 TraceCheckUtils]: 26: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:49,237 INFO L290 TraceCheckUtils]: 25: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:49,237 INFO L290 TraceCheckUtils]: 24: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:49,237 INFO L272 TraceCheckUtils]: 23: Hoare triple {15901#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* 3 (* (* main_~p~0 2) main_~B~0))) (+ main_~A~0 (* main_~d~0 6)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:49,237 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {15305#true} {15901#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* 3 (* (* main_~p~0 2) main_~B~0))) (+ main_~A~0 (* main_~d~0 6)))} #82#return; {15901#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* 3 (* (* main_~p~0 2) main_~B~0))) (+ main_~A~0 (* main_~d~0 6)))} is VALID [2022-04-08 13:28:49,238 INFO L290 TraceCheckUtils]: 21: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:49,238 INFO L290 TraceCheckUtils]: 20: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:49,238 INFO L290 TraceCheckUtils]: 19: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:49,238 INFO L272 TraceCheckUtils]: 18: Hoare triple {15901#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* 3 (* (* main_~p~0 2) main_~B~0))) (+ main_~A~0 (* main_~d~0 6)))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:49,238 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {15305#true} {15901#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* 3 (* (* main_~p~0 2) main_~B~0))) (+ main_~A~0 (* main_~d~0 6)))} #80#return; {15901#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* 3 (* (* main_~p~0 2) main_~B~0))) (+ main_~A~0 (* main_~d~0 6)))} is VALID [2022-04-08 13:28:49,238 INFO L290 TraceCheckUtils]: 16: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:49,238 INFO L290 TraceCheckUtils]: 15: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:49,238 INFO L290 TraceCheckUtils]: 14: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:49,238 INFO L272 TraceCheckUtils]: 13: Hoare triple {15901#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* 3 (* (* main_~p~0 2) main_~B~0))) (+ main_~A~0 (* main_~d~0 6)))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:49,239 INFO L290 TraceCheckUtils]: 12: Hoare triple {15901#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* 3 (* (* main_~p~0 2) main_~B~0))) (+ main_~A~0 (* main_~d~0 6)))} assume !false; {15901#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* 3 (* (* main_~p~0 2) main_~B~0))) (+ main_~A~0 (* main_~d~0 6)))} is VALID [2022-04-08 13:28:49,239 INFO L290 TraceCheckUtils]: 11: Hoare triple {15305#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {15901#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* 3 (* (* main_~p~0 2) main_~B~0))) (+ main_~A~0 (* main_~d~0 6)))} is VALID [2022-04-08 13:28:49,239 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {15305#true} {15305#true} #78#return; {15305#true} is VALID [2022-04-08 13:28:49,239 INFO L290 TraceCheckUtils]: 9: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:49,239 INFO L290 TraceCheckUtils]: 8: Hoare triple {15305#true} assume !(0 == ~cond); {15305#true} is VALID [2022-04-08 13:28:49,239 INFO L290 TraceCheckUtils]: 7: Hoare triple {15305#true} ~cond := #in~cond; {15305#true} is VALID [2022-04-08 13:28:49,239 INFO L272 TraceCheckUtils]: 6: Hoare triple {15305#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {15305#true} is VALID [2022-04-08 13:28:49,240 INFO L290 TraceCheckUtils]: 5: Hoare triple {15305#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {15305#true} is VALID [2022-04-08 13:28:49,240 INFO L272 TraceCheckUtils]: 4: Hoare triple {15305#true} call #t~ret5 := main(); {15305#true} is VALID [2022-04-08 13:28:49,240 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {15305#true} {15305#true} #94#return; {15305#true} is VALID [2022-04-08 13:28:49,240 INFO L290 TraceCheckUtils]: 2: Hoare triple {15305#true} assume true; {15305#true} is VALID [2022-04-08 13:28:49,240 INFO L290 TraceCheckUtils]: 1: Hoare triple {15305#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {15305#true} is VALID [2022-04-08 13:28:49,240 INFO L272 TraceCheckUtils]: 0: Hoare triple {15305#true} call ULTIMATE.init(); {15305#true} is VALID [2022-04-08 13:28:49,241 INFO L134 CoverageAnalysis]: Checked inductivity of 551 backedges. 32 proven. 39 refuted. 0 times theorem prover too weak. 480 trivial. 0 not checked. [2022-04-08 13:28:49,241 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-08 13:28:49,241 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [385661937] [2022-04-08 13:28:49,241 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-08 13:28:49,241 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1322659176] [2022-04-08 13:28:49,241 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1322659176] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-08 13:28:49,241 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-08 13:28:49,241 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [11, 11] total 18 [2022-04-08 13:28:49,241 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-08 13:28:49,241 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [321147519] [2022-04-08 13:28:49,241 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [321147519] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:28:49,242 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:28:49,242 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [11] imperfect sequences [] total 11 [2022-04-08 13:28:49,242 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [582787859] [2022-04-08 13:28:49,242 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-08 13:28:49,242 INFO L78 Accepts]: Start accepts. Automaton has has 11 states, 11 states have (on average 2.5454545454545454) internal successors, (28), 10 states have internal predecessors, (28), 7 states have call successors, (20), 2 states have call predecessors, (20), 1 states have return successors, (18), 6 states have call predecessors, (18), 6 states have call successors, (18) Word has length 111 [2022-04-08 13:28:49,242 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-08 13:28:49,242 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 11 states, 11 states have (on average 2.5454545454545454) internal successors, (28), 10 states have internal predecessors, (28), 7 states have call successors, (20), 2 states have call predecessors, (20), 1 states have return successors, (18), 6 states have call predecessors, (18), 6 states have call successors, (18) [2022-04-08 13:28:49,303 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 66 edges. 66 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:28:49,303 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 11 states [2022-04-08 13:28:49,303 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-08 13:28:49,303 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 11 interpolants. [2022-04-08 13:28:49,303 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=76, Invalid=229, Unknown=1, NotChecked=0, Total=306 [2022-04-08 13:28:49,304 INFO L87 Difference]: Start difference. First operand 120 states and 137 transitions. Second operand has 11 states, 11 states have (on average 2.5454545454545454) internal successors, (28), 10 states have internal predecessors, (28), 7 states have call successors, (20), 2 states have call predecessors, (20), 1 states have return successors, (18), 6 states have call predecessors, (18), 6 states have call successors, (18) [2022-04-08 13:28:51,035 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:28:51,035 INFO L93 Difference]: Finished difference Result 180 states and 208 transitions. [2022-04-08 13:28:51,035 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 11 states. [2022-04-08 13:28:51,035 INFO L78 Accepts]: Start accepts. Automaton has has 11 states, 11 states have (on average 2.5454545454545454) internal successors, (28), 10 states have internal predecessors, (28), 7 states have call successors, (20), 2 states have call predecessors, (20), 1 states have return successors, (18), 6 states have call predecessors, (18), 6 states have call successors, (18) Word has length 111 [2022-04-08 13:28:51,035 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-08 13:28:51,035 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 11 states, 11 states have (on average 2.5454545454545454) internal successors, (28), 10 states have internal predecessors, (28), 7 states have call successors, (20), 2 states have call predecessors, (20), 1 states have return successors, (18), 6 states have call predecessors, (18), 6 states have call successors, (18) [2022-04-08 13:28:51,037 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 11 states to 11 states and 109 transitions. [2022-04-08 13:28:51,037 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 11 states, 11 states have (on average 2.5454545454545454) internal successors, (28), 10 states have internal predecessors, (28), 7 states have call successors, (20), 2 states have call predecessors, (20), 1 states have return successors, (18), 6 states have call predecessors, (18), 6 states have call successors, (18) [2022-04-08 13:28:51,038 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 11 states to 11 states and 109 transitions. [2022-04-08 13:28:51,038 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 11 states and 109 transitions. [2022-04-08 13:28:51,146 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 109 edges. 109 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:28:51,149 INFO L225 Difference]: With dead ends: 180 [2022-04-08 13:28:51,149 INFO L226 Difference]: Without dead ends: 178 [2022-04-08 13:28:51,149 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 222 GetRequests, 202 SyntacticMatches, 3 SemanticMatches, 17 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 7 ImplicationChecksByTransitivity, 6.7s TimeCoverageRelationStatistics Valid=80, Invalid=261, Unknown=1, NotChecked=0, Total=342 [2022-04-08 13:28:51,149 INFO L913 BasicCegarLoop]: 58 mSDtfsCounter, 10 mSDsluCounter, 246 mSDsCounter, 0 mSdLazyCounter, 562 mSolverCounterSat, 18 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.6s Time, 0 mProtectedPredicate, 0 mProtectedAction, 15 SdHoareTripleChecker+Valid, 304 SdHoareTripleChecker+Invalid, 580 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 18 IncrementalHoareTripleChecker+Valid, 562 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.6s IncrementalHoareTripleChecker+Time [2022-04-08 13:28:51,150 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [15 Valid, 304 Invalid, 580 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [18 Valid, 562 Invalid, 0 Unknown, 0 Unchecked, 0.6s Time] [2022-04-08 13:28:51,150 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 178 states. [2022-04-08 13:28:51,332 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 178 to 175. [2022-04-08 13:28:51,332 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-08 13:28:51,333 INFO L82 GeneralOperation]: Start isEquivalent. First operand 178 states. Second operand has 175 states, 109 states have (on average 1.1009174311926606) internal successors, (120), 111 states have internal predecessors, (120), 42 states have call successors, (42), 24 states have call predecessors, (42), 23 states have return successors, (40), 39 states have call predecessors, (40), 40 states have call successors, (40) [2022-04-08 13:28:51,333 INFO L74 IsIncluded]: Start isIncluded. First operand 178 states. Second operand has 175 states, 109 states have (on average 1.1009174311926606) internal successors, (120), 111 states have internal predecessors, (120), 42 states have call successors, (42), 24 states have call predecessors, (42), 23 states have return successors, (40), 39 states have call predecessors, (40), 40 states have call successors, (40) [2022-04-08 13:28:51,333 INFO L87 Difference]: Start difference. First operand 178 states. Second operand has 175 states, 109 states have (on average 1.1009174311926606) internal successors, (120), 111 states have internal predecessors, (120), 42 states have call successors, (42), 24 states have call predecessors, (42), 23 states have return successors, (40), 39 states have call predecessors, (40), 40 states have call successors, (40) [2022-04-08 13:28:51,336 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:28:51,336 INFO L93 Difference]: Finished difference Result 178 states and 206 transitions. [2022-04-08 13:28:51,336 INFO L276 IsEmpty]: Start isEmpty. Operand 178 states and 206 transitions. [2022-04-08 13:28:51,336 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:28:51,336 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:28:51,337 INFO L74 IsIncluded]: Start isIncluded. First operand has 175 states, 109 states have (on average 1.1009174311926606) internal successors, (120), 111 states have internal predecessors, (120), 42 states have call successors, (42), 24 states have call predecessors, (42), 23 states have return successors, (40), 39 states have call predecessors, (40), 40 states have call successors, (40) Second operand 178 states. [2022-04-08 13:28:51,337 INFO L87 Difference]: Start difference. First operand has 175 states, 109 states have (on average 1.1009174311926606) internal successors, (120), 111 states have internal predecessors, (120), 42 states have call successors, (42), 24 states have call predecessors, (42), 23 states have return successors, (40), 39 states have call predecessors, (40), 40 states have call successors, (40) Second operand 178 states. [2022-04-08 13:28:51,339 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:28:51,339 INFO L93 Difference]: Finished difference Result 178 states and 206 transitions. [2022-04-08 13:28:51,340 INFO L276 IsEmpty]: Start isEmpty. Operand 178 states and 206 transitions. [2022-04-08 13:28:51,340 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:28:51,340 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:28:51,340 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-08 13:28:51,340 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-08 13:28:51,340 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 175 states, 109 states have (on average 1.1009174311926606) internal successors, (120), 111 states have internal predecessors, (120), 42 states have call successors, (42), 24 states have call predecessors, (42), 23 states have return successors, (40), 39 states have call predecessors, (40), 40 states have call successors, (40) [2022-04-08 13:28:51,343 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 175 states to 175 states and 202 transitions. [2022-04-08 13:28:51,343 INFO L78 Accepts]: Start accepts. Automaton has 175 states and 202 transitions. Word has length 111 [2022-04-08 13:28:51,344 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-08 13:28:51,344 INFO L478 AbstractCegarLoop]: Abstraction has 175 states and 202 transitions. [2022-04-08 13:28:51,344 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 11 states, 11 states have (on average 2.5454545454545454) internal successors, (28), 10 states have internal predecessors, (28), 7 states have call successors, (20), 2 states have call predecessors, (20), 1 states have return successors, (18), 6 states have call predecessors, (18), 6 states have call successors, (18) [2022-04-08 13:28:51,344 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 175 states and 202 transitions. [2022-04-08 13:28:51,683 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 202 edges. 202 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:28:51,683 INFO L276 IsEmpty]: Start isEmpty. Operand 175 states and 202 transitions. [2022-04-08 13:28:51,684 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 125 [2022-04-08 13:28:51,684 INFO L491 BasicCegarLoop]: Found error trace [2022-04-08 13:28:51,684 INFO L499 BasicCegarLoop]: trace histogram [19, 18, 18, 4, 4, 4, 4, 4, 4, 4, 4, 4, 3, 3, 3, 3, 3, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-08 13:28:51,704 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (15)] Forceful destruction successful, exit code 0 [2022-04-08 13:28:51,884 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable16,15 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:28:51,885 INFO L403 AbstractCegarLoop]: === Iteration 18 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-08 13:28:51,885 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-08 13:28:51,885 INFO L85 PathProgramCache]: Analyzing trace with hash -238794489, now seen corresponding path program 15 times [2022-04-08 13:28:51,885 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-08 13:28:51,885 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [777695100] [2022-04-08 13:28:54,446 INFO L97 AcceleratorQvasr]: Qvasr could not accelerate loop because java.lang.UnsupportedOperationException: Cannot deal with arrays. [2022-04-08 13:28:54,446 INFO L274 tedInterpolationCore]: Could not compute an accelerate. [2022-04-08 13:28:54,446 INFO L85 PathProgramCache]: Analyzing trace with hash -238794489, now seen corresponding path program 16 times [2022-04-08 13:28:54,446 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-08 13:28:54,446 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [658052463] [2022-04-08 13:28:54,446 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-08 13:28:54,446 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-08 13:28:54,455 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-08 13:28:54,456 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1370802210] [2022-04-08 13:28:54,456 INFO L93 rtionOrderModulation]: Changing assertion order to TERMS_WITH_SMALL_CONSTANTS_FIRST [2022-04-08 13:28:54,456 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:28:54,456 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-08 13:28:54,457 INFO L229 MonitoredProcess]: Starting monitored process 16 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-08 13:28:54,457 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (16)] Waiting until timeout for monitored process [2022-04-08 13:28:54,517 INFO L228 tOrderPrioritization]: Assert order TERMS_WITH_SMALL_CONSTANTS_FIRST issued 0 check-sat command(s) [2022-04-08 13:28:54,517 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-08 13:28:54,518 INFO L263 TraceCheckSpWp]: Trace formula consists of 256 conjuncts, 49 conjunts are in the unsatisfiable core [2022-04-08 13:28:54,535 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:28:54,537 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-08 13:28:55,346 INFO L272 TraceCheckUtils]: 0: Hoare triple {17056#true} call ULTIMATE.init(); {17056#true} is VALID [2022-04-08 13:28:55,346 INFO L290 TraceCheckUtils]: 1: Hoare triple {17056#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {17056#true} is VALID [2022-04-08 13:28:55,346 INFO L290 TraceCheckUtils]: 2: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:28:55,346 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {17056#true} {17056#true} #94#return; {17056#true} is VALID [2022-04-08 13:28:55,346 INFO L272 TraceCheckUtils]: 4: Hoare triple {17056#true} call #t~ret5 := main(); {17056#true} is VALID [2022-04-08 13:28:55,346 INFO L290 TraceCheckUtils]: 5: Hoare triple {17056#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {17056#true} is VALID [2022-04-08 13:28:55,346 INFO L272 TraceCheckUtils]: 6: Hoare triple {17056#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:28:55,346 INFO L290 TraceCheckUtils]: 7: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:28:55,346 INFO L290 TraceCheckUtils]: 8: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:28:55,346 INFO L290 TraceCheckUtils]: 9: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:28:55,346 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {17056#true} {17056#true} #78#return; {17056#true} is VALID [2022-04-08 13:28:55,347 INFO L290 TraceCheckUtils]: 11: Hoare triple {17056#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {17094#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:28:55,347 INFO L290 TraceCheckUtils]: 12: Hoare triple {17094#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !false; {17094#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:28:55,347 INFO L272 TraceCheckUtils]: 13: Hoare triple {17094#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:28:55,347 INFO L290 TraceCheckUtils]: 14: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:28:55,347 INFO L290 TraceCheckUtils]: 15: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:28:55,347 INFO L290 TraceCheckUtils]: 16: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:28:55,348 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {17056#true} {17094#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #80#return; {17094#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:28:55,348 INFO L272 TraceCheckUtils]: 18: Hoare triple {17094#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:28:55,348 INFO L290 TraceCheckUtils]: 19: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:28:55,348 INFO L290 TraceCheckUtils]: 20: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:28:55,348 INFO L290 TraceCheckUtils]: 21: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:28:55,349 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {17056#true} {17094#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #82#return; {17094#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:28:55,349 INFO L272 TraceCheckUtils]: 23: Hoare triple {17094#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:28:55,349 INFO L290 TraceCheckUtils]: 24: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:28:55,349 INFO L290 TraceCheckUtils]: 25: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:28:55,349 INFO L290 TraceCheckUtils]: 26: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:28:55,349 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {17056#true} {17094#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #84#return; {17094#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:28:55,350 INFO L290 TraceCheckUtils]: 28: Hoare triple {17094#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {17146#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:28:55,350 INFO L290 TraceCheckUtils]: 29: Hoare triple {17146#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} assume !false; {17146#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:28:55,350 INFO L272 TraceCheckUtils]: 30: Hoare triple {17146#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:28:55,350 INFO L290 TraceCheckUtils]: 31: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:28:55,350 INFO L290 TraceCheckUtils]: 32: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:28:55,350 INFO L290 TraceCheckUtils]: 33: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:28:55,351 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {17056#true} {17146#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #80#return; {17146#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:28:55,351 INFO L272 TraceCheckUtils]: 35: Hoare triple {17146#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:28:55,351 INFO L290 TraceCheckUtils]: 36: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:28:55,351 INFO L290 TraceCheckUtils]: 37: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:28:55,351 INFO L290 TraceCheckUtils]: 38: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:28:55,351 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {17056#true} {17146#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #82#return; {17146#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:28:55,352 INFO L272 TraceCheckUtils]: 40: Hoare triple {17146#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:28:55,352 INFO L290 TraceCheckUtils]: 41: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:28:55,352 INFO L290 TraceCheckUtils]: 42: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:28:55,352 INFO L290 TraceCheckUtils]: 43: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:28:55,352 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {17056#true} {17146#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #84#return; {17146#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:28:55,353 INFO L290 TraceCheckUtils]: 45: Hoare triple {17146#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {17198#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:28:55,353 INFO L290 TraceCheckUtils]: 46: Hoare triple {17198#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} assume !false; {17198#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:28:55,353 INFO L272 TraceCheckUtils]: 47: Hoare triple {17198#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:28:55,353 INFO L290 TraceCheckUtils]: 48: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:28:55,353 INFO L290 TraceCheckUtils]: 49: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:28:55,353 INFO L290 TraceCheckUtils]: 50: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:28:55,354 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {17056#true} {17198#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} #80#return; {17198#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:28:55,354 INFO L272 TraceCheckUtils]: 52: Hoare triple {17198#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:28:55,354 INFO L290 TraceCheckUtils]: 53: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:28:55,354 INFO L290 TraceCheckUtils]: 54: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:28:55,354 INFO L290 TraceCheckUtils]: 55: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:28:55,355 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {17056#true} {17198#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} #82#return; {17198#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:28:55,355 INFO L272 TraceCheckUtils]: 57: Hoare triple {17198#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:28:55,355 INFO L290 TraceCheckUtils]: 58: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:28:55,355 INFO L290 TraceCheckUtils]: 59: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:28:55,355 INFO L290 TraceCheckUtils]: 60: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:28:55,355 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {17056#true} {17198#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} #84#return; {17198#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:28:55,356 INFO L290 TraceCheckUtils]: 62: Hoare triple {17198#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:28:55,356 INFO L290 TraceCheckUtils]: 63: Hoare triple {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} assume !false; {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:28:55,356 INFO L272 TraceCheckUtils]: 64: Hoare triple {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:28:55,356 INFO L290 TraceCheckUtils]: 65: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:28:55,356 INFO L290 TraceCheckUtils]: 66: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:28:55,356 INFO L290 TraceCheckUtils]: 67: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:28:55,357 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {17056#true} {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} #80#return; {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:28:55,357 INFO L272 TraceCheckUtils]: 69: Hoare triple {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:28:55,357 INFO L290 TraceCheckUtils]: 70: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:28:55,357 INFO L290 TraceCheckUtils]: 71: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:28:55,357 INFO L290 TraceCheckUtils]: 72: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:28:55,357 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {17056#true} {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} #82#return; {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:28:55,357 INFO L272 TraceCheckUtils]: 74: Hoare triple {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:28:55,357 INFO L290 TraceCheckUtils]: 75: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:28:55,358 INFO L290 TraceCheckUtils]: 76: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:28:55,358 INFO L290 TraceCheckUtils]: 77: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:28:55,358 INFO L284 TraceCheckUtils]: 78: Hoare quadruple {17056#true} {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} #84#return; {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:28:55,358 INFO L290 TraceCheckUtils]: 79: Hoare triple {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} assume !(~r~0 >= ~d~0); {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:28:55,359 INFO L290 TraceCheckUtils]: 80: Hoare triple {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} assume !false; {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:28:55,359 INFO L272 TraceCheckUtils]: 81: Hoare triple {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:28:55,359 INFO L290 TraceCheckUtils]: 82: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:28:55,359 INFO L290 TraceCheckUtils]: 83: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:28:55,359 INFO L290 TraceCheckUtils]: 84: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:28:55,359 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {17056#true} {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} #86#return; {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:28:55,360 INFO L272 TraceCheckUtils]: 86: Hoare triple {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:28:55,360 INFO L290 TraceCheckUtils]: 87: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:28:55,360 INFO L290 TraceCheckUtils]: 88: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:28:55,360 INFO L290 TraceCheckUtils]: 89: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:28:55,360 INFO L284 TraceCheckUtils]: 90: Hoare quadruple {17056#true} {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} #88#return; {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:28:55,361 INFO L290 TraceCheckUtils]: 91: Hoare triple {17250#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {17198#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:28:55,361 INFO L290 TraceCheckUtils]: 92: Hoare triple {17198#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {17341#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} is VALID [2022-04-08 13:28:55,361 INFO L290 TraceCheckUtils]: 93: Hoare triple {17341#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} assume !false; {17341#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} is VALID [2022-04-08 13:28:55,361 INFO L272 TraceCheckUtils]: 94: Hoare triple {17341#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:28:55,362 INFO L290 TraceCheckUtils]: 95: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:28:55,362 INFO L290 TraceCheckUtils]: 96: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:28:55,362 INFO L290 TraceCheckUtils]: 97: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:28:55,362 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {17056#true} {17341#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} #86#return; {17341#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} is VALID [2022-04-08 13:28:55,362 INFO L272 TraceCheckUtils]: 99: Hoare triple {17341#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:28:55,362 INFO L290 TraceCheckUtils]: 100: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:28:55,362 INFO L290 TraceCheckUtils]: 101: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:28:55,362 INFO L290 TraceCheckUtils]: 102: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:28:55,363 INFO L284 TraceCheckUtils]: 103: Hoare quadruple {17056#true} {17341#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} #88#return; {17341#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} is VALID [2022-04-08 13:28:55,363 INFO L290 TraceCheckUtils]: 104: Hoare triple {17341#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {17378#(and (= main_~p~0 (div main_~q~0 2)) (= (+ main_~A~0 (* main_~B~0 (- 4))) main_~r~0) (= main_~B~0 1) (= main_~q~0 4) (= main_~d~0 (div (* main_~B~0 4) 2)))} is VALID [2022-04-08 13:28:55,364 INFO L290 TraceCheckUtils]: 105: Hoare triple {17378#(and (= main_~p~0 (div main_~q~0 2)) (= (+ main_~A~0 (* main_~B~0 (- 4))) main_~r~0) (= main_~B~0 1) (= main_~q~0 4) (= main_~d~0 (div (* main_~B~0 4) 2)))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {17382#(and (= (+ (* (- 1) main_~d~0) main_~A~0 (* main_~B~0 (- 4))) main_~r~0) (= (+ main_~p~0 4) main_~q~0) (= main_~p~0 2) (= main_~B~0 1) (= main_~d~0 (div (* main_~B~0 4) 2)))} is VALID [2022-04-08 13:28:55,365 INFO L290 TraceCheckUtils]: 106: Hoare triple {17382#(and (= (+ (* (- 1) main_~d~0) main_~A~0 (* main_~B~0 (- 4))) main_~r~0) (= (+ main_~p~0 4) main_~q~0) (= main_~p~0 2) (= main_~B~0 1) (= main_~d~0 (div (* main_~B~0 4) 2)))} assume !false; {17382#(and (= (+ (* (- 1) main_~d~0) main_~A~0 (* main_~B~0 (- 4))) main_~r~0) (= (+ main_~p~0 4) main_~q~0) (= main_~p~0 2) (= main_~B~0 1) (= main_~d~0 (div (* main_~B~0 4) 2)))} is VALID [2022-04-08 13:28:55,365 INFO L272 TraceCheckUtils]: 107: Hoare triple {17382#(and (= (+ (* (- 1) main_~d~0) main_~A~0 (* main_~B~0 (- 4))) main_~r~0) (= (+ main_~p~0 4) main_~q~0) (= main_~p~0 2) (= main_~B~0 1) (= main_~d~0 (div (* main_~B~0 4) 2)))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:28:55,365 INFO L290 TraceCheckUtils]: 108: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:28:55,365 INFO L290 TraceCheckUtils]: 109: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:28:55,365 INFO L290 TraceCheckUtils]: 110: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:28:55,366 INFO L284 TraceCheckUtils]: 111: Hoare quadruple {17056#true} {17382#(and (= (+ (* (- 1) main_~d~0) main_~A~0 (* main_~B~0 (- 4))) main_~r~0) (= (+ main_~p~0 4) main_~q~0) (= main_~p~0 2) (= main_~B~0 1) (= main_~d~0 (div (* main_~B~0 4) 2)))} #86#return; {17382#(and (= (+ (* (- 1) main_~d~0) main_~A~0 (* main_~B~0 (- 4))) main_~r~0) (= (+ main_~p~0 4) main_~q~0) (= main_~p~0 2) (= main_~B~0 1) (= main_~d~0 (div (* main_~B~0 4) 2)))} is VALID [2022-04-08 13:28:55,366 INFO L272 TraceCheckUtils]: 112: Hoare triple {17382#(and (= (+ (* (- 1) main_~d~0) main_~A~0 (* main_~B~0 (- 4))) main_~r~0) (= (+ main_~p~0 4) main_~q~0) (= main_~p~0 2) (= main_~B~0 1) (= main_~d~0 (div (* main_~B~0 4) 2)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:28:55,366 INFO L290 TraceCheckUtils]: 113: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:28:55,366 INFO L290 TraceCheckUtils]: 114: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:28:55,366 INFO L290 TraceCheckUtils]: 115: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:28:55,366 INFO L284 TraceCheckUtils]: 116: Hoare quadruple {17056#true} {17382#(and (= (+ (* (- 1) main_~d~0) main_~A~0 (* main_~B~0 (- 4))) main_~r~0) (= (+ main_~p~0 4) main_~q~0) (= main_~p~0 2) (= main_~B~0 1) (= main_~d~0 (div (* main_~B~0 4) 2)))} #88#return; {17382#(and (= (+ (* (- 1) main_~d~0) main_~A~0 (* main_~B~0 (- 4))) main_~r~0) (= (+ main_~p~0 4) main_~q~0) (= main_~p~0 2) (= main_~B~0 1) (= main_~d~0 (div (* main_~B~0 4) 2)))} is VALID [2022-04-08 13:28:55,367 INFO L290 TraceCheckUtils]: 117: Hoare triple {17382#(and (= (+ (* (- 1) main_~d~0) main_~A~0 (* main_~B~0 (- 4))) main_~r~0) (= (+ main_~p~0 4) main_~q~0) (= main_~p~0 2) (= main_~B~0 1) (= main_~d~0 (div (* main_~B~0 4) 2)))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {17419#(and (= main_~d~0 (div (div (* main_~B~0 4) 2) 2)) (= main_~r~0 (+ (* (- 1) (div (* main_~B~0 4) 2)) main_~A~0 (* main_~B~0 (- 4)))) (= main_~q~0 6) (= main_~B~0 1) (= main_~p~0 1))} is VALID [2022-04-08 13:28:55,368 INFO L290 TraceCheckUtils]: 118: Hoare triple {17419#(and (= main_~d~0 (div (div (* main_~B~0 4) 2) 2)) (= main_~r~0 (+ (* (- 1) (div (* main_~B~0 4) 2)) main_~A~0 (* main_~B~0 (- 4)))) (= main_~q~0 6) (= main_~B~0 1) (= main_~p~0 1))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {17423#(and (= (+ main_~q~0 (- 6)) 1) (= main_~B~0 1) (= (+ main_~r~0 (div (div (* main_~B~0 4) 2) 2)) (+ (* (- 1) (div (* main_~B~0 4) 2)) main_~A~0 (* main_~B~0 (- 4)))))} is VALID [2022-04-08 13:28:55,368 INFO L290 TraceCheckUtils]: 119: Hoare triple {17423#(and (= (+ main_~q~0 (- 6)) 1) (= main_~B~0 1) (= (+ main_~r~0 (div (div (* main_~B~0 4) 2) 2)) (+ (* (- 1) (div (* main_~B~0 4) 2)) main_~A~0 (* main_~B~0 (- 4)))))} assume !false; {17423#(and (= (+ main_~q~0 (- 6)) 1) (= main_~B~0 1) (= (+ main_~r~0 (div (div (* main_~B~0 4) 2) 2)) (+ (* (- 1) (div (* main_~B~0 4) 2)) main_~A~0 (* main_~B~0 (- 4)))))} is VALID [2022-04-08 13:28:55,369 INFO L272 TraceCheckUtils]: 120: Hoare triple {17423#(and (= (+ main_~q~0 (- 6)) 1) (= main_~B~0 1) (= (+ main_~r~0 (div (div (* main_~B~0 4) 2) 2)) (+ (* (- 1) (div (* main_~B~0 4) 2)) main_~A~0 (* main_~B~0 (- 4)))))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {17430#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:28:55,369 INFO L290 TraceCheckUtils]: 121: Hoare triple {17430#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {17434#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:28:55,369 INFO L290 TraceCheckUtils]: 122: Hoare triple {17434#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {17057#false} is VALID [2022-04-08 13:28:55,369 INFO L290 TraceCheckUtils]: 123: Hoare triple {17057#false} assume !false; {17057#false} is VALID [2022-04-08 13:28:55,370 INFO L134 CoverageAnalysis]: Checked inductivity of 699 backedges. 36 proven. 51 refuted. 0 times theorem prover too weak. 612 trivial. 0 not checked. [2022-04-08 13:28:55,370 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-08 13:29:32,168 WARN L232 SmtUtils]: Spent 6.91s on a formula simplification that was a NOOP. DAG size: 433 (called from [L 360] de.uni_freiburg.informatik.ultimate.lib.modelcheckerutils.smt.predicates.PredicateUnifier.getOrConstructPredicate) [2022-04-08 13:31:25,508 INFO L290 TraceCheckUtils]: 123: Hoare triple {17057#false} assume !false; {17057#false} is VALID [2022-04-08 13:31:25,509 INFO L290 TraceCheckUtils]: 122: Hoare triple {17434#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {17057#false} is VALID [2022-04-08 13:31:25,509 INFO L290 TraceCheckUtils]: 121: Hoare triple {17430#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {17434#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:31:25,509 INFO L272 TraceCheckUtils]: 120: Hoare triple {17450#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {17430#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:31:25,510 INFO L290 TraceCheckUtils]: 119: Hoare triple {17450#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} assume !false; {17450#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:31:25,526 INFO L290 TraceCheckUtils]: 118: Hoare triple {17457#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {17450#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:31:25,546 INFO L290 TraceCheckUtils]: 117: Hoare triple {17461#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {17457#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} is VALID [2022-04-08 13:31:25,547 INFO L284 TraceCheckUtils]: 116: Hoare quadruple {17056#true} {17461#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} #88#return; {17461#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:31:25,547 INFO L290 TraceCheckUtils]: 115: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:31:25,547 INFO L290 TraceCheckUtils]: 114: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:31:25,547 INFO L290 TraceCheckUtils]: 113: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:31:25,547 INFO L272 TraceCheckUtils]: 112: Hoare triple {17461#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:31:25,547 INFO L284 TraceCheckUtils]: 111: Hoare quadruple {17056#true} {17461#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} #86#return; {17461#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:31:25,547 INFO L290 TraceCheckUtils]: 110: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:31:25,547 INFO L290 TraceCheckUtils]: 109: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:31:25,548 INFO L290 TraceCheckUtils]: 108: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:31:25,548 INFO L272 TraceCheckUtils]: 107: Hoare triple {17461#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:31:25,549 INFO L290 TraceCheckUtils]: 106: Hoare triple {17461#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} assume !false; {17461#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:31:25,571 INFO L290 TraceCheckUtils]: 105: Hoare triple {17498#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {17461#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:31:25,977 INFO L290 TraceCheckUtils]: 104: Hoare triple {17502#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {17498#(and (or (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))))) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 main_~p~0 (div main_~p~0 2) 1))) main_~A~0) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)))))} is VALID [2022-04-08 13:31:25,978 INFO L284 TraceCheckUtils]: 103: Hoare quadruple {17056#true} {17502#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} #88#return; {17502#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:31:25,978 INFO L290 TraceCheckUtils]: 102: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:31:25,978 INFO L290 TraceCheckUtils]: 101: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:31:25,978 INFO L290 TraceCheckUtils]: 100: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:31:25,978 INFO L272 TraceCheckUtils]: 99: Hoare triple {17502#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:31:25,979 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {17056#true} {17502#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} #86#return; {17502#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:31:25,979 INFO L290 TraceCheckUtils]: 97: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:31:25,979 INFO L290 TraceCheckUtils]: 96: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:31:25,979 INFO L290 TraceCheckUtils]: 95: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:31:25,979 INFO L272 TraceCheckUtils]: 94: Hoare triple {17502#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:31:25,984 INFO L290 TraceCheckUtils]: 93: Hoare triple {17502#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} assume !false; {17502#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:31:26,457 INFO L290 TraceCheckUtils]: 92: Hoare triple {17539#(and (or (and (or (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 2) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 2) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (= (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)))) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)))))) (or (not (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod main_~p~0 2) 0)))))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {17502#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (= (+ (- 1) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))))))) (or (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 2) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))) (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div main_~d~0 2))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))))} is VALID [2022-04-08 13:31:28,465 WARN L290 TraceCheckUtils]: 91: Hoare triple {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {17539#(and (or (and (or (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 2) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 2) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (= (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)))) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)))))) (or (not (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod main_~p~0 2) 0)))))} is UNKNOWN [2022-04-08 13:31:28,467 INFO L284 TraceCheckUtils]: 90: Hoare quadruple {17056#true} {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} #88#return; {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:31:28,467 INFO L290 TraceCheckUtils]: 89: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:31:28,467 INFO L290 TraceCheckUtils]: 88: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:31:28,467 INFO L290 TraceCheckUtils]: 87: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:31:28,467 INFO L272 TraceCheckUtils]: 86: Hoare triple {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:31:28,469 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {17056#true} {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} #86#return; {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:31:28,469 INFO L290 TraceCheckUtils]: 84: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:31:28,469 INFO L290 TraceCheckUtils]: 83: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:31:28,469 INFO L290 TraceCheckUtils]: 82: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:31:28,470 INFO L272 TraceCheckUtils]: 81: Hoare triple {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:31:28,484 INFO L290 TraceCheckUtils]: 80: Hoare triple {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} assume !false; {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:31:28,499 INFO L290 TraceCheckUtils]: 79: Hoare triple {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} assume !(~r~0 >= ~d~0); {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:31:28,500 INFO L284 TraceCheckUtils]: 78: Hoare quadruple {17056#true} {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} #84#return; {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:31:28,501 INFO L290 TraceCheckUtils]: 77: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:31:28,501 INFO L290 TraceCheckUtils]: 76: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:31:28,501 INFO L290 TraceCheckUtils]: 75: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:31:28,501 INFO L272 TraceCheckUtils]: 74: Hoare triple {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:31:28,503 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {17056#true} {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} #82#return; {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:31:28,503 INFO L290 TraceCheckUtils]: 72: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:31:28,503 INFO L290 TraceCheckUtils]: 71: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:31:28,503 INFO L290 TraceCheckUtils]: 70: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:31:28,504 INFO L272 TraceCheckUtils]: 69: Hoare triple {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:31:28,505 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {17056#true} {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} #80#return; {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:31:28,505 INFO L290 TraceCheckUtils]: 67: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:31:28,505 INFO L290 TraceCheckUtils]: 66: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:31:28,505 INFO L290 TraceCheckUtils]: 65: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:31:28,506 INFO L272 TraceCheckUtils]: 64: Hoare triple {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:31:28,520 INFO L290 TraceCheckUtils]: 63: Hoare triple {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} assume !false; {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:31:30,527 WARN L290 TraceCheckUtils]: 62: Hoare triple {17539#(and (or (and (or (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 2) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 2) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (= (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)))) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)))))) (or (not (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod main_~p~0 2) 0)))))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {17543#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))))) (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)))))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))) (or (and (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0))))))) (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0)) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))))) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (not (< (div main_~p~0 2) 0))) (or (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))))))) (or (and (or (and (or (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 3 (div (+ (div main_~p~0 2) 1) 2) (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0) (= main_~A~0 (+ (* main_~B~0 (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= main_~A~0 (+ main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))))) (or (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (- 3) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (- 2) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 2) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 2 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (* main_~B~0 (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is UNKNOWN [2022-04-08 13:31:30,528 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {17056#true} {17539#(and (or (and (or (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 2) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 2) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (= (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)))) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)))))) (or (not (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod main_~p~0 2) 0)))))} #84#return; {17539#(and (or (and (or (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 2) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 2) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (= (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)))) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)))))) (or (not (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod main_~p~0 2) 0)))))} is VALID [2022-04-08 13:31:30,528 INFO L290 TraceCheckUtils]: 60: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:31:30,529 INFO L290 TraceCheckUtils]: 59: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:31:30,529 INFO L290 TraceCheckUtils]: 58: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:31:30,529 INFO L272 TraceCheckUtils]: 57: Hoare triple {17539#(and (or (and (or (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 2) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 2) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (= (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)))) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)))))) (or (not (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod main_~p~0 2) 0)))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:31:30,529 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {17056#true} {17539#(and (or (and (or (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 2) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 2) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (= (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)))) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)))))) (or (not (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod main_~p~0 2) 0)))))} #82#return; {17539#(and (or (and (or (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 2) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 2) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (= (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)))) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)))))) (or (not (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod main_~p~0 2) 0)))))} is VALID [2022-04-08 13:31:30,529 INFO L290 TraceCheckUtils]: 55: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:31:30,529 INFO L290 TraceCheckUtils]: 54: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:31:30,530 INFO L290 TraceCheckUtils]: 53: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:31:30,530 INFO L272 TraceCheckUtils]: 52: Hoare triple {17539#(and (or (and (or (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 2) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 2) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (= (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)))) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)))))) (or (not (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod main_~p~0 2) 0)))))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:31:30,530 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {17056#true} {17539#(and (or (and (or (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 2) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 2) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (= (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)))) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)))))) (or (not (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod main_~p~0 2) 0)))))} #80#return; {17539#(and (or (and (or (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 2) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 2) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (= (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)))) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)))))) (or (not (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod main_~p~0 2) 0)))))} is VALID [2022-04-08 13:31:30,530 INFO L290 TraceCheckUtils]: 50: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:31:30,530 INFO L290 TraceCheckUtils]: 49: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:31:30,531 INFO L290 TraceCheckUtils]: 48: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:31:30,531 INFO L272 TraceCheckUtils]: 47: Hoare triple {17539#(and (or (and (or (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 2) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 2) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (= (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)))) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)))))) (or (not (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod main_~p~0 2) 0)))))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:31:30,535 INFO L290 TraceCheckUtils]: 46: Hoare triple {17539#(and (or (and (or (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 2) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 2) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (= (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)))) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)))))) (or (not (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod main_~p~0 2) 0)))))} assume !false; {17539#(and (or (and (or (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 2) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 2) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (= (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)))) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)))))) (or (not (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod main_~p~0 2) 0)))))} is VALID [2022-04-08 13:31:30,701 INFO L290 TraceCheckUtils]: 45: Hoare triple {17682#(and (or (and (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2))) main_~A~0) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (and (not (= (mod (div (* main_~d~0 2) 2) 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0))) (= (mod (div (* main_~p~0 2) 2) 2) 0)) (or (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (= (mod (div (* main_~d~0 2) 2) 2) 0) (not (< main_~d~0 0))))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {17539#(and (or (and (or (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 2) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 2) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (- 2) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))))))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (or (= (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)))) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2) 1)) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)))))) (or (not (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0)) (or (= main_~A~0 (+ (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) (* main_~B~0 (+ main_~q~0 main_~p~0 2 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2))) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (- 1) main_~d~0) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod main_~p~0 2) 0)))))} is VALID [2022-04-08 13:31:30,702 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {17056#true} {17682#(and (or (and (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2))) main_~A~0) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (and (not (= (mod (div (* main_~d~0 2) 2) 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0))) (= (mod (div (* main_~p~0 2) 2) 2) 0)) (or (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (= (mod (div (* main_~d~0 2) 2) 2) 0) (not (< main_~d~0 0))))} #84#return; {17682#(and (or (and (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2))) main_~A~0) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (and (not (= (mod (div (* main_~d~0 2) 2) 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0))) (= (mod (div (* main_~p~0 2) 2) 2) 0)) (or (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (= (mod (div (* main_~d~0 2) 2) 2) 0) (not (< main_~d~0 0))))} is VALID [2022-04-08 13:31:30,702 INFO L290 TraceCheckUtils]: 43: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:31:30,702 INFO L290 TraceCheckUtils]: 42: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:31:30,702 INFO L290 TraceCheckUtils]: 41: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:31:30,702 INFO L272 TraceCheckUtils]: 40: Hoare triple {17682#(and (or (and (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2))) main_~A~0) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (and (not (= (mod (div (* main_~d~0 2) 2) 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0))) (= (mod (div (* main_~p~0 2) 2) 2) 0)) (or (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (= (mod (div (* main_~d~0 2) 2) 2) 0) (not (< main_~d~0 0))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:31:30,703 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {17056#true} {17682#(and (or (and (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2))) main_~A~0) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (and (not (= (mod (div (* main_~d~0 2) 2) 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0))) (= (mod (div (* main_~p~0 2) 2) 2) 0)) (or (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (= (mod (div (* main_~d~0 2) 2) 2) 0) (not (< main_~d~0 0))))} #82#return; {17682#(and (or (and (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2))) main_~A~0) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (and (not (= (mod (div (* main_~d~0 2) 2) 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0))) (= (mod (div (* main_~p~0 2) 2) 2) 0)) (or (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (= (mod (div (* main_~d~0 2) 2) 2) 0) (not (< main_~d~0 0))))} is VALID [2022-04-08 13:31:30,703 INFO L290 TraceCheckUtils]: 38: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:31:30,703 INFO L290 TraceCheckUtils]: 37: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:31:30,703 INFO L290 TraceCheckUtils]: 36: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:31:30,703 INFO L272 TraceCheckUtils]: 35: Hoare triple {17682#(and (or (and (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2))) main_~A~0) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (and (not (= (mod (div (* main_~d~0 2) 2) 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0))) (= (mod (div (* main_~p~0 2) 2) 2) 0)) (or (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (= (mod (div (* main_~d~0 2) 2) 2) 0) (not (< main_~d~0 0))))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:31:30,704 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {17056#true} {17682#(and (or (and (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2))) main_~A~0) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (and (not (= (mod (div (* main_~d~0 2) 2) 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0))) (= (mod (div (* main_~p~0 2) 2) 2) 0)) (or (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (= (mod (div (* main_~d~0 2) 2) 2) 0) (not (< main_~d~0 0))))} #80#return; {17682#(and (or (and (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2))) main_~A~0) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (and (not (= (mod (div (* main_~d~0 2) 2) 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0))) (= (mod (div (* main_~p~0 2) 2) 2) 0)) (or (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (= (mod (div (* main_~d~0 2) 2) 2) 0) (not (< main_~d~0 0))))} is VALID [2022-04-08 13:31:30,704 INFO L290 TraceCheckUtils]: 33: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:31:30,704 INFO L290 TraceCheckUtils]: 32: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:31:30,704 INFO L290 TraceCheckUtils]: 31: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:31:30,704 INFO L272 TraceCheckUtils]: 30: Hoare triple {17682#(and (or (and (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2))) main_~A~0) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (and (not (= (mod (div (* main_~d~0 2) 2) 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0))) (= (mod (div (* main_~p~0 2) 2) 2) 0)) (or (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (= (mod (div (* main_~d~0 2) 2) 2) 0) (not (< main_~d~0 0))))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:31:30,705 INFO L290 TraceCheckUtils]: 29: Hoare triple {17682#(and (or (and (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2))) main_~A~0) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (and (not (= (mod (div (* main_~d~0 2) 2) 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0))) (= (mod (div (* main_~p~0 2) 2) 2) 0)) (or (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (= (mod (div (* main_~d~0 2) 2) 2) 0) (not (< main_~d~0 0))))} assume !false; {17682#(and (or (and (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2))) main_~A~0) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (and (not (= (mod (div (* main_~d~0 2) 2) 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0))) (= (mod (div (* main_~p~0 2) 2) 2) 0)) (or (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (= (mod (div (* main_~d~0 2) 2) 2) 0) (not (< main_~d~0 0))))} is VALID [2022-04-08 13:31:30,717 INFO L290 TraceCheckUtils]: 28: Hoare triple {17734#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* (* main_~B~0 main_~p~0) 7)) (+ main_~A~0 (* 7 main_~d~0)))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {17682#(and (or (and (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2))) main_~A~0) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (and (not (= (mod (div (* main_~d~0 2) 2) 2) 0)) (< main_~d~0 0))) (or (and (or (not (< main_~p~0 0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)) (* (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0 1) main_~B~0))) (= (mod (div (* main_~p~0 2) 2) 2) 0)) (or (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (- 1) (* (- 2) main_~d~0) (* main_~B~0 (+ (div (* main_~p~0 2) 2) (* main_~p~0 2) (div (div (* main_~p~0 2) 2) 2) main_~q~0)) main_~r~0 (* (- 1) (div (div (* main_~d~0 2) 2) 2)))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0)))) (= (mod (div (* main_~d~0 2) 2) 2) 0) (not (< main_~d~0 0))))} is VALID [2022-04-08 13:31:30,718 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {17056#true} {17734#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* (* main_~B~0 main_~p~0) 7)) (+ main_~A~0 (* 7 main_~d~0)))} #84#return; {17734#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* (* main_~B~0 main_~p~0) 7)) (+ main_~A~0 (* 7 main_~d~0)))} is VALID [2022-04-08 13:31:30,718 INFO L290 TraceCheckUtils]: 26: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:31:30,718 INFO L290 TraceCheckUtils]: 25: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:31:30,718 INFO L290 TraceCheckUtils]: 24: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:31:30,718 INFO L272 TraceCheckUtils]: 23: Hoare triple {17734#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* (* main_~B~0 main_~p~0) 7)) (+ main_~A~0 (* 7 main_~d~0)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:31:30,718 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {17056#true} {17734#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* (* main_~B~0 main_~p~0) 7)) (+ main_~A~0 (* 7 main_~d~0)))} #82#return; {17734#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* (* main_~B~0 main_~p~0) 7)) (+ main_~A~0 (* 7 main_~d~0)))} is VALID [2022-04-08 13:31:30,718 INFO L290 TraceCheckUtils]: 21: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:31:30,719 INFO L290 TraceCheckUtils]: 20: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:31:30,719 INFO L290 TraceCheckUtils]: 19: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:31:30,719 INFO L272 TraceCheckUtils]: 18: Hoare triple {17734#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* (* main_~B~0 main_~p~0) 7)) (+ main_~A~0 (* 7 main_~d~0)))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:31:30,719 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {17056#true} {17734#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* (* main_~B~0 main_~p~0) 7)) (+ main_~A~0 (* 7 main_~d~0)))} #80#return; {17734#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* (* main_~B~0 main_~p~0) 7)) (+ main_~A~0 (* 7 main_~d~0)))} is VALID [2022-04-08 13:31:30,719 INFO L290 TraceCheckUtils]: 16: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:31:30,719 INFO L290 TraceCheckUtils]: 15: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:31:30,719 INFO L290 TraceCheckUtils]: 14: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:31:30,719 INFO L272 TraceCheckUtils]: 13: Hoare triple {17734#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* (* main_~B~0 main_~p~0) 7)) (+ main_~A~0 (* 7 main_~d~0)))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:31:30,720 INFO L290 TraceCheckUtils]: 12: Hoare triple {17734#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* (* main_~B~0 main_~p~0) 7)) (+ main_~A~0 (* 7 main_~d~0)))} assume !false; {17734#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* (* main_~B~0 main_~p~0) 7)) (+ main_~A~0 (* 7 main_~d~0)))} is VALID [2022-04-08 13:31:30,720 INFO L290 TraceCheckUtils]: 11: Hoare triple {17056#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {17734#(= (+ (* main_~B~0 main_~q~0) main_~r~0 (* (* main_~B~0 main_~p~0) 7)) (+ main_~A~0 (* 7 main_~d~0)))} is VALID [2022-04-08 13:31:30,720 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {17056#true} {17056#true} #78#return; {17056#true} is VALID [2022-04-08 13:31:30,720 INFO L290 TraceCheckUtils]: 9: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:31:30,720 INFO L290 TraceCheckUtils]: 8: Hoare triple {17056#true} assume !(0 == ~cond); {17056#true} is VALID [2022-04-08 13:31:30,720 INFO L290 TraceCheckUtils]: 7: Hoare triple {17056#true} ~cond := #in~cond; {17056#true} is VALID [2022-04-08 13:31:30,720 INFO L272 TraceCheckUtils]: 6: Hoare triple {17056#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {17056#true} is VALID [2022-04-08 13:31:30,720 INFO L290 TraceCheckUtils]: 5: Hoare triple {17056#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {17056#true} is VALID [2022-04-08 13:31:30,720 INFO L272 TraceCheckUtils]: 4: Hoare triple {17056#true} call #t~ret5 := main(); {17056#true} is VALID [2022-04-08 13:31:30,721 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {17056#true} {17056#true} #94#return; {17056#true} is VALID [2022-04-08 13:31:30,721 INFO L290 TraceCheckUtils]: 2: Hoare triple {17056#true} assume true; {17056#true} is VALID [2022-04-08 13:31:30,721 INFO L290 TraceCheckUtils]: 1: Hoare triple {17056#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {17056#true} is VALID [2022-04-08 13:31:30,721 INFO L272 TraceCheckUtils]: 0: Hoare triple {17056#true} call ULTIMATE.init(); {17056#true} is VALID [2022-04-08 13:31:30,723 INFO L134 CoverageAnalysis]: Checked inductivity of 699 backedges. 36 proven. 51 refuted. 0 times theorem prover too weak. 612 trivial. 0 not checked. [2022-04-08 13:31:30,724 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-08 13:31:30,724 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [658052463] [2022-04-08 13:31:30,724 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-08 13:31:30,724 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1370802210] [2022-04-08 13:31:30,724 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1370802210] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-08 13:31:30,724 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-08 13:31:30,724 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [13, 13] total 22 [2022-04-08 13:31:30,724 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-08 13:31:30,724 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [777695100] [2022-04-08 13:31:30,724 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [777695100] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:31:30,724 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:31:30,724 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [13] imperfect sequences [] total 13 [2022-04-08 13:31:30,724 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [708920384] [2022-04-08 13:31:30,724 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-08 13:31:30,725 INFO L78 Accepts]: Start accepts. Automaton has has 13 states, 13 states have (on average 2.3846153846153846) internal successors, (31), 12 states have internal predecessors, (31), 8 states have call successors, (22), 2 states have call predecessors, (22), 1 states have return successors, (20), 7 states have call predecessors, (20), 7 states have call successors, (20) Word has length 124 [2022-04-08 13:31:30,725 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-08 13:31:30,725 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 13 states, 13 states have (on average 2.3846153846153846) internal successors, (31), 12 states have internal predecessors, (31), 8 states have call successors, (22), 2 states have call predecessors, (22), 1 states have return successors, (20), 7 states have call predecessors, (20), 7 states have call successors, (20) [2022-04-08 13:31:30,792 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 73 edges. 73 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:31:30,792 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 13 states [2022-04-08 13:31:30,792 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-08 13:31:30,793 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 13 interpolants. [2022-04-08 13:31:30,793 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=114, Invalid=344, Unknown=4, NotChecked=0, Total=462 [2022-04-08 13:31:30,793 INFO L87 Difference]: Start difference. First operand 175 states and 202 transitions. Second operand has 13 states, 13 states have (on average 2.3846153846153846) internal successors, (31), 12 states have internal predecessors, (31), 8 states have call successors, (22), 2 states have call predecessors, (22), 1 states have return successors, (20), 7 states have call predecessors, (20), 7 states have call successors, (20) [2022-04-08 13:31:33,129 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:31:33,129 INFO L93 Difference]: Finished difference Result 219 states and 257 transitions. [2022-04-08 13:31:33,129 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 13 states. [2022-04-08 13:31:33,129 INFO L78 Accepts]: Start accepts. Automaton has has 13 states, 13 states have (on average 2.3846153846153846) internal successors, (31), 12 states have internal predecessors, (31), 8 states have call successors, (22), 2 states have call predecessors, (22), 1 states have return successors, (20), 7 states have call predecessors, (20), 7 states have call successors, (20) Word has length 124 [2022-04-08 13:31:33,129 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-08 13:31:33,129 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 13 states, 13 states have (on average 2.3846153846153846) internal successors, (31), 12 states have internal predecessors, (31), 8 states have call successors, (22), 2 states have call predecessors, (22), 1 states have return successors, (20), 7 states have call predecessors, (20), 7 states have call successors, (20) [2022-04-08 13:31:33,131 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 13 states to 13 states and 143 transitions. [2022-04-08 13:31:33,131 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 13 states, 13 states have (on average 2.3846153846153846) internal successors, (31), 12 states have internal predecessors, (31), 8 states have call successors, (22), 2 states have call predecessors, (22), 1 states have return successors, (20), 7 states have call predecessors, (20), 7 states have call successors, (20) [2022-04-08 13:31:33,132 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 13 states to 13 states and 143 transitions. [2022-04-08 13:31:33,133 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 13 states and 143 transitions. [2022-04-08 13:31:33,275 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 143 edges. 143 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:31:33,277 INFO L225 Difference]: With dead ends: 219 [2022-04-08 13:31:33,278 INFO L226 Difference]: Without dead ends: 187 [2022-04-08 13:31:33,278 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 248 GetRequests, 224 SyntacticMatches, 3 SemanticMatches, 21 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 9 ImplicationChecksByTransitivity, 24.1s TimeCoverageRelationStatistics Valid=118, Invalid=384, Unknown=4, NotChecked=0, Total=506 [2022-04-08 13:31:33,278 INFO L913 BasicCegarLoop]: 63 mSDtfsCounter, 13 mSDsluCounter, 313 mSDsCounter, 0 mSdLazyCounter, 825 mSolverCounterSat, 25 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.9s Time, 0 mProtectedPredicate, 0 mProtectedAction, 21 SdHoareTripleChecker+Valid, 376 SdHoareTripleChecker+Invalid, 850 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 25 IncrementalHoareTripleChecker+Valid, 825 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.9s IncrementalHoareTripleChecker+Time [2022-04-08 13:31:33,278 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [21 Valid, 376 Invalid, 850 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [25 Valid, 825 Invalid, 0 Unknown, 0 Unchecked, 0.9s Time] [2022-04-08 13:31:33,279 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 187 states. [2022-04-08 13:31:33,438 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 187 to 184. [2022-04-08 13:31:33,438 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-08 13:31:33,438 INFO L82 GeneralOperation]: Start isEquivalent. First operand 187 states. Second operand has 184 states, 116 states have (on average 1.0948275862068966) internal successors, (127), 118 states have internal predecessors, (127), 42 states have call successors, (42), 26 states have call predecessors, (42), 25 states have return successors, (40), 39 states have call predecessors, (40), 40 states have call successors, (40) [2022-04-08 13:31:33,439 INFO L74 IsIncluded]: Start isIncluded. First operand 187 states. Second operand has 184 states, 116 states have (on average 1.0948275862068966) internal successors, (127), 118 states have internal predecessors, (127), 42 states have call successors, (42), 26 states have call predecessors, (42), 25 states have return successors, (40), 39 states have call predecessors, (40), 40 states have call successors, (40) [2022-04-08 13:31:33,439 INFO L87 Difference]: Start difference. First operand 187 states. Second operand has 184 states, 116 states have (on average 1.0948275862068966) internal successors, (127), 118 states have internal predecessors, (127), 42 states have call successors, (42), 26 states have call predecessors, (42), 25 states have return successors, (40), 39 states have call predecessors, (40), 40 states have call successors, (40) [2022-04-08 13:31:33,441 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:31:33,441 INFO L93 Difference]: Finished difference Result 187 states and 213 transitions. [2022-04-08 13:31:33,441 INFO L276 IsEmpty]: Start isEmpty. Operand 187 states and 213 transitions. [2022-04-08 13:31:33,442 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:31:33,442 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:31:33,442 INFO L74 IsIncluded]: Start isIncluded. First operand has 184 states, 116 states have (on average 1.0948275862068966) internal successors, (127), 118 states have internal predecessors, (127), 42 states have call successors, (42), 26 states have call predecessors, (42), 25 states have return successors, (40), 39 states have call predecessors, (40), 40 states have call successors, (40) Second operand 187 states. [2022-04-08 13:31:33,442 INFO L87 Difference]: Start difference. First operand has 184 states, 116 states have (on average 1.0948275862068966) internal successors, (127), 118 states have internal predecessors, (127), 42 states have call successors, (42), 26 states have call predecessors, (42), 25 states have return successors, (40), 39 states have call predecessors, (40), 40 states have call successors, (40) Second operand 187 states. [2022-04-08 13:31:33,445 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:31:33,445 INFO L93 Difference]: Finished difference Result 187 states and 213 transitions. [2022-04-08 13:31:33,445 INFO L276 IsEmpty]: Start isEmpty. Operand 187 states and 213 transitions. [2022-04-08 13:31:33,445 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:31:33,445 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:31:33,445 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-08 13:31:33,445 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-08 13:31:33,445 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 184 states, 116 states have (on average 1.0948275862068966) internal successors, (127), 118 states have internal predecessors, (127), 42 states have call successors, (42), 26 states have call predecessors, (42), 25 states have return successors, (40), 39 states have call predecessors, (40), 40 states have call successors, (40) [2022-04-08 13:31:33,448 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 184 states to 184 states and 209 transitions. [2022-04-08 13:31:33,448 INFO L78 Accepts]: Start accepts. Automaton has 184 states and 209 transitions. Word has length 124 [2022-04-08 13:31:33,448 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-08 13:31:33,448 INFO L478 AbstractCegarLoop]: Abstraction has 184 states and 209 transitions. [2022-04-08 13:31:33,449 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 13 states, 13 states have (on average 2.3846153846153846) internal successors, (31), 12 states have internal predecessors, (31), 8 states have call successors, (22), 2 states have call predecessors, (22), 1 states have return successors, (20), 7 states have call predecessors, (20), 7 states have call successors, (20) [2022-04-08 13:31:33,449 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 184 states and 209 transitions. [2022-04-08 13:31:33,749 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 209 edges. 209 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:31:33,750 INFO L276 IsEmpty]: Start isEmpty. Operand 184 states and 209 transitions. [2022-04-08 13:31:33,750 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 125 [2022-04-08 13:31:33,750 INFO L491 BasicCegarLoop]: Found error trace [2022-04-08 13:31:33,750 INFO L499 BasicCegarLoop]: trace histogram [19, 18, 18, 4, 4, 4, 4, 4, 4, 4, 4, 4, 3, 3, 3, 3, 3, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-08 13:31:33,766 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (16)] Forceful destruction successful, exit code 0 [2022-04-08 13:31:33,951 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 16 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable17 [2022-04-08 13:31:33,951 INFO L403 AbstractCegarLoop]: === Iteration 19 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-08 13:31:33,951 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-08 13:31:33,951 INFO L85 PathProgramCache]: Analyzing trace with hash -1927738231, now seen corresponding path program 1 times [2022-04-08 13:31:33,951 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-08 13:31:33,951 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [511354882] [2022-04-08 13:31:36,555 INFO L97 AcceleratorQvasr]: Qvasr could not accelerate loop because java.lang.UnsupportedOperationException: Cannot deal with arrays. [2022-04-08 13:31:36,555 INFO L274 tedInterpolationCore]: Could not compute an accelerate. [2022-04-08 13:31:36,556 INFO L85 PathProgramCache]: Analyzing trace with hash -1927738231, now seen corresponding path program 2 times [2022-04-08 13:31:36,556 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-08 13:31:36,556 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [178590358] [2022-04-08 13:31:36,556 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-08 13:31:36,556 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-08 13:31:36,564 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-08 13:31:36,565 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [187213465] [2022-04-08 13:31:36,565 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-08 13:31:36,565 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:31:36,565 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-08 13:31:36,566 INFO L229 MonitoredProcess]: Starting monitored process 17 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-08 13:31:36,574 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (17)] Waiting until timeout for monitored process [2022-04-08 13:31:36,631 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-08 13:31:36,631 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-08 13:31:36,633 INFO L263 TraceCheckSpWp]: Trace formula consists of 283 conjuncts, 49 conjunts are in the unsatisfiable core [2022-04-08 13:31:36,661 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:31:36,663 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-08 13:31:37,657 INFO L272 TraceCheckUtils]: 0: Hoare triple {19003#true} call ULTIMATE.init(); {19003#true} is VALID [2022-04-08 13:31:37,658 INFO L290 TraceCheckUtils]: 1: Hoare triple {19003#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {19003#true} is VALID [2022-04-08 13:31:37,658 INFO L290 TraceCheckUtils]: 2: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:31:37,658 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {19003#true} {19003#true} #94#return; {19003#true} is VALID [2022-04-08 13:31:37,658 INFO L272 TraceCheckUtils]: 4: Hoare triple {19003#true} call #t~ret5 := main(); {19003#true} is VALID [2022-04-08 13:31:37,658 INFO L290 TraceCheckUtils]: 5: Hoare triple {19003#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {19003#true} is VALID [2022-04-08 13:31:37,658 INFO L272 TraceCheckUtils]: 6: Hoare triple {19003#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:31:37,658 INFO L290 TraceCheckUtils]: 7: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:31:37,658 INFO L290 TraceCheckUtils]: 8: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:31:37,658 INFO L290 TraceCheckUtils]: 9: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:31:37,658 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {19003#true} {19003#true} #78#return; {19003#true} is VALID [2022-04-08 13:31:37,658 INFO L290 TraceCheckUtils]: 11: Hoare triple {19003#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {19041#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:31:37,659 INFO L290 TraceCheckUtils]: 12: Hoare triple {19041#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !false; {19041#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:31:37,659 INFO L272 TraceCheckUtils]: 13: Hoare triple {19041#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:31:37,659 INFO L290 TraceCheckUtils]: 14: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:31:37,659 INFO L290 TraceCheckUtils]: 15: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:31:37,659 INFO L290 TraceCheckUtils]: 16: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:31:37,659 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {19003#true} {19041#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #80#return; {19041#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:31:37,660 INFO L272 TraceCheckUtils]: 18: Hoare triple {19041#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:31:37,660 INFO L290 TraceCheckUtils]: 19: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:31:37,660 INFO L290 TraceCheckUtils]: 20: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:31:37,660 INFO L290 TraceCheckUtils]: 21: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:31:37,660 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {19003#true} {19041#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #82#return; {19041#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:31:37,660 INFO L272 TraceCheckUtils]: 23: Hoare triple {19041#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:31:37,660 INFO L290 TraceCheckUtils]: 24: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:31:37,660 INFO L290 TraceCheckUtils]: 25: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:31:37,660 INFO L290 TraceCheckUtils]: 26: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:31:37,661 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {19003#true} {19041#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} #84#return; {19041#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} is VALID [2022-04-08 13:31:37,661 INFO L290 TraceCheckUtils]: 28: Hoare triple {19041#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~B~0 main_~d~0) (= main_~p~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {19093#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:31:37,662 INFO L290 TraceCheckUtils]: 29: Hoare triple {19093#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} assume !false; {19093#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:31:37,662 INFO L272 TraceCheckUtils]: 30: Hoare triple {19093#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:31:37,662 INFO L290 TraceCheckUtils]: 31: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:31:37,662 INFO L290 TraceCheckUtils]: 32: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:31:37,662 INFO L290 TraceCheckUtils]: 33: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:31:37,662 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {19003#true} {19093#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #80#return; {19093#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:31:37,662 INFO L272 TraceCheckUtils]: 35: Hoare triple {19093#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:31:37,662 INFO L290 TraceCheckUtils]: 36: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:31:37,662 INFO L290 TraceCheckUtils]: 37: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:31:37,663 INFO L290 TraceCheckUtils]: 38: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:31:37,663 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {19003#true} {19093#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #82#return; {19093#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:31:37,663 INFO L272 TraceCheckUtils]: 40: Hoare triple {19093#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:31:37,663 INFO L290 TraceCheckUtils]: 41: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:31:37,663 INFO L290 TraceCheckUtils]: 42: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:31:37,663 INFO L290 TraceCheckUtils]: 43: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:31:37,664 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {19003#true} {19093#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} #84#return; {19093#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:31:37,664 INFO L290 TraceCheckUtils]: 45: Hoare triple {19093#(and (= main_~A~0 main_~r~0) (= (* main_~B~0 2) main_~d~0) (= main_~p~0 2) (= main_~q~0 0) (= main_~B~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {19145#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:31:37,664 INFO L290 TraceCheckUtils]: 46: Hoare triple {19145#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} assume !false; {19145#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:31:37,664 INFO L272 TraceCheckUtils]: 47: Hoare triple {19145#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:31:37,664 INFO L290 TraceCheckUtils]: 48: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:31:37,665 INFO L290 TraceCheckUtils]: 49: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:31:37,665 INFO L290 TraceCheckUtils]: 50: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:31:37,665 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {19003#true} {19145#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} #80#return; {19145#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:31:37,665 INFO L272 TraceCheckUtils]: 52: Hoare triple {19145#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:31:37,665 INFO L290 TraceCheckUtils]: 53: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:31:37,665 INFO L290 TraceCheckUtils]: 54: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:31:37,665 INFO L290 TraceCheckUtils]: 55: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:31:37,666 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {19003#true} {19145#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} #82#return; {19145#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:31:37,666 INFO L272 TraceCheckUtils]: 57: Hoare triple {19145#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:31:37,666 INFO L290 TraceCheckUtils]: 58: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:31:37,666 INFO L290 TraceCheckUtils]: 59: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:31:37,666 INFO L290 TraceCheckUtils]: 60: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:31:37,666 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {19003#true} {19145#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} #84#return; {19145#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} is VALID [2022-04-08 13:31:37,667 INFO L290 TraceCheckUtils]: 62: Hoare triple {19145#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~d~0 (* main_~B~0 4)) (= main_~p~0 4))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:31:37,667 INFO L290 TraceCheckUtils]: 63: Hoare triple {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} assume !false; {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:31:37,667 INFO L272 TraceCheckUtils]: 64: Hoare triple {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:31:37,667 INFO L290 TraceCheckUtils]: 65: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:31:37,667 INFO L290 TraceCheckUtils]: 66: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:31:37,667 INFO L290 TraceCheckUtils]: 67: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:31:37,668 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {19003#true} {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} #80#return; {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:31:37,668 INFO L272 TraceCheckUtils]: 69: Hoare triple {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:31:37,668 INFO L290 TraceCheckUtils]: 70: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:31:37,668 INFO L290 TraceCheckUtils]: 71: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:31:37,668 INFO L290 TraceCheckUtils]: 72: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:31:37,669 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {19003#true} {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} #82#return; {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:31:37,669 INFO L272 TraceCheckUtils]: 74: Hoare triple {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:31:37,669 INFO L290 TraceCheckUtils]: 75: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:31:37,669 INFO L290 TraceCheckUtils]: 76: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:31:37,669 INFO L290 TraceCheckUtils]: 77: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:31:37,669 INFO L284 TraceCheckUtils]: 78: Hoare quadruple {19003#true} {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} #84#return; {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:31:37,670 INFO L290 TraceCheckUtils]: 79: Hoare triple {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} assume !(~r~0 >= ~d~0); {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:31:37,670 INFO L290 TraceCheckUtils]: 80: Hoare triple {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} assume !false; {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:31:37,670 INFO L272 TraceCheckUtils]: 81: Hoare triple {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:31:37,670 INFO L290 TraceCheckUtils]: 82: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:31:37,670 INFO L290 TraceCheckUtils]: 83: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:31:37,670 INFO L290 TraceCheckUtils]: 84: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:31:37,671 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {19003#true} {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} #86#return; {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:31:37,671 INFO L272 TraceCheckUtils]: 86: Hoare triple {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:31:37,671 INFO L290 TraceCheckUtils]: 87: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:31:37,671 INFO L290 TraceCheckUtils]: 88: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:31:37,671 INFO L290 TraceCheckUtils]: 89: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:31:37,671 INFO L284 TraceCheckUtils]: 90: Hoare quadruple {19003#true} {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} #88#return; {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} is VALID [2022-04-08 13:31:37,672 INFO L290 TraceCheckUtils]: 91: Hoare triple {19197#(and (= main_~A~0 main_~r~0) (= main_~p~0 8) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (* main_~B~0 8) main_~d~0))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {19285#(and (= (div (* main_~B~0 8) 2) main_~d~0) (= main_~A~0 main_~r~0) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~p~0 4))} is VALID [2022-04-08 13:31:37,672 INFO L290 TraceCheckUtils]: 92: Hoare triple {19285#(and (= (div (* main_~B~0 8) 2) main_~d~0) (= main_~A~0 main_~r~0) (<= (* main_~B~0 4) main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= main_~p~0 4))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {19289#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (<= (* main_~B~0 4) main_~A~0) (= (div (* main_~B~0 8) 2) main_~d~0) (= main_~B~0 1) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} is VALID [2022-04-08 13:31:37,673 INFO L290 TraceCheckUtils]: 93: Hoare triple {19289#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (<= (* main_~B~0 4) main_~A~0) (= (div (* main_~B~0 8) 2) main_~d~0) (= main_~B~0 1) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} assume !false; {19289#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (<= (* main_~B~0 4) main_~A~0) (= (div (* main_~B~0 8) 2) main_~d~0) (= main_~B~0 1) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} is VALID [2022-04-08 13:31:37,673 INFO L272 TraceCheckUtils]: 94: Hoare triple {19289#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (<= (* main_~B~0 4) main_~A~0) (= (div (* main_~B~0 8) 2) main_~d~0) (= main_~B~0 1) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:31:37,673 INFO L290 TraceCheckUtils]: 95: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:31:37,673 INFO L290 TraceCheckUtils]: 96: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:31:37,673 INFO L290 TraceCheckUtils]: 97: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:31:37,673 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {19003#true} {19289#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (<= (* main_~B~0 4) main_~A~0) (= (div (* main_~B~0 8) 2) main_~d~0) (= main_~B~0 1) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} #86#return; {19289#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (<= (* main_~B~0 4) main_~A~0) (= (div (* main_~B~0 8) 2) main_~d~0) (= main_~B~0 1) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} is VALID [2022-04-08 13:31:37,674 INFO L272 TraceCheckUtils]: 99: Hoare triple {19289#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (<= (* main_~B~0 4) main_~A~0) (= (div (* main_~B~0 8) 2) main_~d~0) (= main_~B~0 1) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:31:37,674 INFO L290 TraceCheckUtils]: 100: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:31:37,674 INFO L290 TraceCheckUtils]: 101: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:31:37,674 INFO L290 TraceCheckUtils]: 102: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:31:37,674 INFO L284 TraceCheckUtils]: 103: Hoare quadruple {19003#true} {19289#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (<= (* main_~B~0 4) main_~A~0) (= (div (* main_~B~0 8) 2) main_~d~0) (= main_~B~0 1) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} #88#return; {19289#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (<= (* main_~B~0 4) main_~A~0) (= (div (* main_~B~0 8) 2) main_~d~0) (= main_~B~0 1) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} is VALID [2022-04-08 13:31:37,675 INFO L290 TraceCheckUtils]: 104: Hoare triple {19289#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (<= (* main_~B~0 4) main_~A~0) (= (div (* main_~B~0 8) 2) main_~d~0) (= main_~B~0 1) (= main_~p~0 4) (= main_~r~0 (+ (* (- 1) main_~d~0) main_~A~0)))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {19326#(and (= main_~p~0 (div main_~q~0 2)) (<= (* main_~B~0 4) main_~A~0) (= main_~B~0 1) (= main_~q~0 4) (= main_~r~0 (+ main_~A~0 (* (- 1) (div (* main_~B~0 8) 2)))) (= main_~d~0 (div (div (* main_~B~0 8) 2) 2)))} is VALID [2022-04-08 13:31:37,675 INFO L290 TraceCheckUtils]: 105: Hoare triple {19326#(and (= main_~p~0 (div main_~q~0 2)) (<= (* main_~B~0 4) main_~A~0) (= main_~B~0 1) (= main_~q~0 4) (= main_~r~0 (+ main_~A~0 (* (- 1) (div (* main_~B~0 8) 2)))) (= main_~d~0 (div (div (* main_~B~0 8) 2) 2)))} assume !(~r~0 >= ~d~0); {19330#(and (= main_~p~0 (div main_~q~0 2)) (<= (* main_~B~0 4) main_~A~0) (not (<= main_~d~0 main_~r~0)) (= main_~B~0 1) (= main_~q~0 4) (= main_~r~0 (+ main_~A~0 (* (- 1) (div (* main_~B~0 8) 2)))) (= main_~d~0 (div (div (* main_~B~0 8) 2) 2)))} is VALID [2022-04-08 13:31:37,676 INFO L290 TraceCheckUtils]: 106: Hoare triple {19330#(and (= main_~p~0 (div main_~q~0 2)) (<= (* main_~B~0 4) main_~A~0) (not (<= main_~d~0 main_~r~0)) (= main_~B~0 1) (= main_~q~0 4) (= main_~r~0 (+ main_~A~0 (* (- 1) (div (* main_~B~0 8) 2)))) (= main_~d~0 (div (div (* main_~B~0 8) 2) 2)))} assume !false; {19330#(and (= main_~p~0 (div main_~q~0 2)) (<= (* main_~B~0 4) main_~A~0) (not (<= main_~d~0 main_~r~0)) (= main_~B~0 1) (= main_~q~0 4) (= main_~r~0 (+ main_~A~0 (* (- 1) (div (* main_~B~0 8) 2)))) (= main_~d~0 (div (div (* main_~B~0 8) 2) 2)))} is VALID [2022-04-08 13:31:37,676 INFO L272 TraceCheckUtils]: 107: Hoare triple {19330#(and (= main_~p~0 (div main_~q~0 2)) (<= (* main_~B~0 4) main_~A~0) (not (<= main_~d~0 main_~r~0)) (= main_~B~0 1) (= main_~q~0 4) (= main_~r~0 (+ main_~A~0 (* (- 1) (div (* main_~B~0 8) 2)))) (= main_~d~0 (div (div (* main_~B~0 8) 2) 2)))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:31:37,676 INFO L290 TraceCheckUtils]: 108: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:31:37,676 INFO L290 TraceCheckUtils]: 109: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:31:37,676 INFO L290 TraceCheckUtils]: 110: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:31:37,676 INFO L284 TraceCheckUtils]: 111: Hoare quadruple {19003#true} {19330#(and (= main_~p~0 (div main_~q~0 2)) (<= (* main_~B~0 4) main_~A~0) (not (<= main_~d~0 main_~r~0)) (= main_~B~0 1) (= main_~q~0 4) (= main_~r~0 (+ main_~A~0 (* (- 1) (div (* main_~B~0 8) 2)))) (= main_~d~0 (div (div (* main_~B~0 8) 2) 2)))} #86#return; {19330#(and (= main_~p~0 (div main_~q~0 2)) (<= (* main_~B~0 4) main_~A~0) (not (<= main_~d~0 main_~r~0)) (= main_~B~0 1) (= main_~q~0 4) (= main_~r~0 (+ main_~A~0 (* (- 1) (div (* main_~B~0 8) 2)))) (= main_~d~0 (div (div (* main_~B~0 8) 2) 2)))} is VALID [2022-04-08 13:31:37,676 INFO L272 TraceCheckUtils]: 112: Hoare triple {19330#(and (= main_~p~0 (div main_~q~0 2)) (<= (* main_~B~0 4) main_~A~0) (not (<= main_~d~0 main_~r~0)) (= main_~B~0 1) (= main_~q~0 4) (= main_~r~0 (+ main_~A~0 (* (- 1) (div (* main_~B~0 8) 2)))) (= main_~d~0 (div (div (* main_~B~0 8) 2) 2)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:31:37,676 INFO L290 TraceCheckUtils]: 113: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:31:37,676 INFO L290 TraceCheckUtils]: 114: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:31:37,676 INFO L290 TraceCheckUtils]: 115: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:31:37,677 INFO L284 TraceCheckUtils]: 116: Hoare quadruple {19003#true} {19330#(and (= main_~p~0 (div main_~q~0 2)) (<= (* main_~B~0 4) main_~A~0) (not (<= main_~d~0 main_~r~0)) (= main_~B~0 1) (= main_~q~0 4) (= main_~r~0 (+ main_~A~0 (* (- 1) (div (* main_~B~0 8) 2)))) (= main_~d~0 (div (div (* main_~B~0 8) 2) 2)))} #88#return; {19330#(and (= main_~p~0 (div main_~q~0 2)) (<= (* main_~B~0 4) main_~A~0) (not (<= main_~d~0 main_~r~0)) (= main_~B~0 1) (= main_~q~0 4) (= main_~r~0 (+ main_~A~0 (* (- 1) (div (* main_~B~0 8) 2)))) (= main_~d~0 (div (div (* main_~B~0 8) 2) 2)))} is VALID [2022-04-08 13:31:37,678 INFO L290 TraceCheckUtils]: 117: Hoare triple {19330#(and (= main_~p~0 (div main_~q~0 2)) (<= (* main_~B~0 4) main_~A~0) (not (<= main_~d~0 main_~r~0)) (= main_~B~0 1) (= main_~q~0 4) (= main_~r~0 (+ main_~A~0 (* (- 1) (div (* main_~B~0 8) 2)))) (= main_~d~0 (div (div (* main_~B~0 8) 2) 2)))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {19367#(and (= (div (div (div (* main_~B~0 8) 2) 2) 2) main_~d~0) (<= (* main_~B~0 4) main_~A~0) (not (<= (* main_~B~0 2) main_~r~0)) (= main_~B~0 1) (= main_~q~0 4) (= main_~r~0 (+ main_~A~0 (* (- 1) (div (* main_~B~0 8) 2)))) (= main_~p~0 (div (div main_~q~0 2) 2)))} is VALID [2022-04-08 13:31:37,678 INFO L290 TraceCheckUtils]: 118: Hoare triple {19367#(and (= (div (div (div (* main_~B~0 8) 2) 2) 2) main_~d~0) (<= (* main_~B~0 4) main_~A~0) (not (<= (* main_~B~0 2) main_~r~0)) (= main_~B~0 1) (= main_~q~0 4) (= main_~r~0 (+ main_~A~0 (* (- 1) (div (* main_~B~0 8) 2)))) (= main_~p~0 (div (div main_~q~0 2) 2)))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {19371#(and (<= (* main_~B~0 4) main_~A~0) (not (<= (* main_~B~0 6) main_~A~0)) (= (+ main_~q~0 (- 4)) 1) (= main_~B~0 1) (= main_~r~0 (+ main_~A~0 (* (- 1) (div (* main_~B~0 8) 2)) (* (- 1) (div (div (div (* main_~B~0 8) 2) 2) 2)))))} is VALID [2022-04-08 13:31:37,679 INFO L290 TraceCheckUtils]: 119: Hoare triple {19371#(and (<= (* main_~B~0 4) main_~A~0) (not (<= (* main_~B~0 6) main_~A~0)) (= (+ main_~q~0 (- 4)) 1) (= main_~B~0 1) (= main_~r~0 (+ main_~A~0 (* (- 1) (div (* main_~B~0 8) 2)) (* (- 1) (div (div (div (* main_~B~0 8) 2) 2) 2)))))} assume !false; {19371#(and (<= (* main_~B~0 4) main_~A~0) (not (<= (* main_~B~0 6) main_~A~0)) (= (+ main_~q~0 (- 4)) 1) (= main_~B~0 1) (= main_~r~0 (+ main_~A~0 (* (- 1) (div (* main_~B~0 8) 2)) (* (- 1) (div (div (div (* main_~B~0 8) 2) 2) 2)))))} is VALID [2022-04-08 13:31:37,679 INFO L272 TraceCheckUtils]: 120: Hoare triple {19371#(and (<= (* main_~B~0 4) main_~A~0) (not (<= (* main_~B~0 6) main_~A~0)) (= (+ main_~q~0 (- 4)) 1) (= main_~B~0 1) (= main_~r~0 (+ main_~A~0 (* (- 1) (div (* main_~B~0 8) 2)) (* (- 1) (div (div (div (* main_~B~0 8) 2) 2) 2)))))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {19378#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:31:37,680 INFO L290 TraceCheckUtils]: 121: Hoare triple {19378#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {19382#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:31:37,680 INFO L290 TraceCheckUtils]: 122: Hoare triple {19382#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {19004#false} is VALID [2022-04-08 13:31:37,680 INFO L290 TraceCheckUtils]: 123: Hoare triple {19004#false} assume !false; {19004#false} is VALID [2022-04-08 13:31:37,681 INFO L134 CoverageAnalysis]: Checked inductivity of 699 backedges. 36 proven. 51 refuted. 0 times theorem prover too weak. 612 trivial. 0 not checked. [2022-04-08 13:31:37,681 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-08 13:32:10,976 WARN L232 SmtUtils]: Spent 9.26s on a formula simplification that was a NOOP. DAG size: 437 (called from [L 360] de.uni_freiburg.informatik.ultimate.lib.modelcheckerutils.smt.predicates.PredicateUnifier.getOrConstructPredicate) [2022-04-08 13:33:38,026 INFO L290 TraceCheckUtils]: 123: Hoare triple {19004#false} assume !false; {19004#false} is VALID [2022-04-08 13:33:38,026 INFO L290 TraceCheckUtils]: 122: Hoare triple {19382#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {19004#false} is VALID [2022-04-08 13:33:38,026 INFO L290 TraceCheckUtils]: 121: Hoare triple {19378#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {19382#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:33:38,027 INFO L272 TraceCheckUtils]: 120: Hoare triple {19398#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {19378#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:33:38,027 INFO L290 TraceCheckUtils]: 119: Hoare triple {19398#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} assume !false; {19398#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:33:38,040 INFO L290 TraceCheckUtils]: 118: Hoare triple {19405#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {19398#(= (+ (* main_~B~0 main_~q~0) main_~r~0) main_~A~0)} is VALID [2022-04-08 13:33:38,062 INFO L290 TraceCheckUtils]: 117: Hoare triple {19409#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {19405#(= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (+ main_~q~0 main_~p~0) main_~B~0)))} is VALID [2022-04-08 13:33:38,063 INFO L284 TraceCheckUtils]: 116: Hoare quadruple {19003#true} {19409#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} #88#return; {19409#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:33:38,063 INFO L290 TraceCheckUtils]: 115: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:33:38,063 INFO L290 TraceCheckUtils]: 114: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:33:38,063 INFO L290 TraceCheckUtils]: 113: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:33:38,063 INFO L272 TraceCheckUtils]: 112: Hoare triple {19409#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:33:38,064 INFO L284 TraceCheckUtils]: 111: Hoare quadruple {19003#true} {19409#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} #86#return; {19409#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:33:38,064 INFO L290 TraceCheckUtils]: 110: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:33:38,064 INFO L290 TraceCheckUtils]: 109: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:33:38,064 INFO L290 TraceCheckUtils]: 108: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:33:38,064 INFO L272 TraceCheckUtils]: 107: Hoare triple {19409#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:33:38,065 INFO L290 TraceCheckUtils]: 106: Hoare triple {19409#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} assume !false; {19409#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:33:38,066 INFO L290 TraceCheckUtils]: 105: Hoare triple {19446#(or (and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)))))))) (<= main_~d~0 main_~r~0))} assume !(~r~0 >= ~d~0); {19409#(and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))))))} is VALID [2022-04-08 13:33:38,265 INFO L290 TraceCheckUtils]: 104: Hoare triple {19450#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (<= (div main_~d~0 2) main_~r~0) (and (or (not (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0) (not (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))))))) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))))))))) (or (<= (+ (div main_~d~0 2) 1) main_~r~0) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (not (< main_~p~0 0)) (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))))))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {19446#(or (and (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (= (+ (- 1) (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)) (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (and (or (not (< main_~p~0 0)) (= (+ (* (+ main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)))))))) (<= main_~d~0 main_~r~0))} is VALID [2022-04-08 13:33:38,266 INFO L284 TraceCheckUtils]: 103: Hoare quadruple {19003#true} {19450#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (<= (div main_~d~0 2) main_~r~0) (and (or (not (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0) (not (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))))))) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))))))))) (or (<= (+ (div main_~d~0 2) 1) main_~r~0) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (not (< main_~p~0 0)) (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))))))} #88#return; {19450#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (<= (div main_~d~0 2) main_~r~0) (and (or (not (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0) (not (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))))))) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))))))))) (or (<= (+ (div main_~d~0 2) 1) main_~r~0) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (not (< main_~p~0 0)) (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))))))} is VALID [2022-04-08 13:33:38,266 INFO L290 TraceCheckUtils]: 102: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:33:38,266 INFO L290 TraceCheckUtils]: 101: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:33:38,266 INFO L290 TraceCheckUtils]: 100: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:33:38,266 INFO L272 TraceCheckUtils]: 99: Hoare triple {19450#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (<= (div main_~d~0 2) main_~r~0) (and (or (not (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0) (not (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))))))) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))))))))) (or (<= (+ (div main_~d~0 2) 1) main_~r~0) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (not (< main_~p~0 0)) (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:33:38,267 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {19003#true} {19450#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (<= (div main_~d~0 2) main_~r~0) (and (or (not (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0) (not (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))))))) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))))))))) (or (<= (+ (div main_~d~0 2) 1) main_~r~0) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (not (< main_~p~0 0)) (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))))))} #86#return; {19450#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (<= (div main_~d~0 2) main_~r~0) (and (or (not (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0) (not (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))))))) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))))))))) (or (<= (+ (div main_~d~0 2) 1) main_~r~0) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (not (< main_~p~0 0)) (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))))))} is VALID [2022-04-08 13:33:38,267 INFO L290 TraceCheckUtils]: 97: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:33:38,267 INFO L290 TraceCheckUtils]: 96: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:33:38,267 INFO L290 TraceCheckUtils]: 95: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:33:38,267 INFO L272 TraceCheckUtils]: 94: Hoare triple {19450#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (<= (div main_~d~0 2) main_~r~0) (and (or (not (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0) (not (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))))))) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))))))))) (or (<= (+ (div main_~d~0 2) 1) main_~r~0) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (not (< main_~p~0 0)) (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))))))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:33:38,272 INFO L290 TraceCheckUtils]: 93: Hoare triple {19450#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (<= (div main_~d~0 2) main_~r~0) (and (or (not (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0) (not (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))))))) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))))))))) (or (<= (+ (div main_~d~0 2) 1) main_~r~0) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (not (< main_~p~0 0)) (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))))))} assume !false; {19450#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (<= (div main_~d~0 2) main_~r~0) (and (or (not (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0) (not (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))))))) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))))))))) (or (<= (+ (div main_~d~0 2) 1) main_~r~0) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (not (< main_~p~0 0)) (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))))))} is VALID [2022-04-08 13:33:38,318 INFO L290 TraceCheckUtils]: 92: Hoare triple {19487#(and (or (and (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) 1) main_~B~0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2)) main_~B~0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2)) main_~B~0)) main_~A~0)) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) 1) main_~B~0)) main_~A~0))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))) (or (not (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0)) main_~A~0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0)))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0))))) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (<= (+ main_~d~0 (div main_~d~0 2)) main_~r~0)) (or (and (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0)))))) (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) 1) main_~B~0)))) (or (= (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2)) main_~B~0)) main_~A~0) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2)) main_~B~0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) 1) main_~B~0)) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)))))))) (<= (+ main_~d~0 (div main_~d~0 2) 1) main_~r~0) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {19450#(and (or (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (<= (div main_~d~0 2) main_~r~0) (and (or (not (< main_~p~0 0)) (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0) (not (= (mod (+ (div main_~p~0 2) 1) 2) 0))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))))))) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))))))))) (or (<= (+ (div main_~d~0 2) 1) main_~r~0) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0) (and (or (not (< main_~p~0 0)) (and (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (= main_~A~0 (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (- 1) (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2)) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (+ (* (+ main_~q~0 (div (div main_~p~0 2) 2) 1) main_~B~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))))))))))} is VALID [2022-04-08 13:33:40,326 WARN L290 TraceCheckUtils]: 91: Hoare triple {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {19487#(and (or (and (or (and (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) 1) main_~B~0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2)) main_~B~0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))) (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2)) main_~B~0)) main_~A~0)) (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) 1) main_~B~0)) main_~A~0))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0))) (or (not (< main_~p~0 0)) (and (or (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0)) main_~A~0)))) (or (not (< (div main_~d~0 2) 0)) (= (mod (div main_~d~0 2) 2) 0) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2)) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0)))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (div main_~d~0 2) 2))) main_~A~0))))) (= (mod main_~p~0 2) 0))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0)) (<= (+ main_~d~0 (div main_~d~0 2)) main_~r~0)) (or (and (or (and (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= main_~A~0 (+ (* main_~B~0 (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0)))))) (or (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (= (+ (- 1) (* main_~B~0 (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2))) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2))) main_~A~0)) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (+ main_~q~0 main_~p~0 (div (+ (div main_~p~0 2) 1) 2) 1) main_~B~0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2)))) (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0)) (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (= 0 (mod (+ (div main_~d~0 2) 1) 2)) (and (or (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)) (= main_~A~0 (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) 1) main_~B~0)))) (or (= (+ (- 1) (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2)) main_~B~0)) main_~A~0) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= main_~A~0 (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2)) main_~B~0))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0)))) (or (= (+ (* (- 1) main_~d~0) main_~r~0 (* (- 1) (div (+ (div main_~d~0 2) 1) 2)) (* (+ main_~q~0 main_~p~0 (div (div main_~p~0 2) 2) 1) main_~B~0)) main_~A~0) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0)))))))) (<= (+ main_~d~0 (div main_~d~0 2) 1) main_~r~0) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is UNKNOWN [2022-04-08 13:33:40,328 INFO L284 TraceCheckUtils]: 90: Hoare quadruple {19003#true} {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} #88#return; {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:33:40,328 INFO L290 TraceCheckUtils]: 89: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:33:40,328 INFO L290 TraceCheckUtils]: 88: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:33:40,329 INFO L290 TraceCheckUtils]: 87: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:33:40,329 INFO L272 TraceCheckUtils]: 86: Hoare triple {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:33:40,330 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {19003#true} {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} #86#return; {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:33:40,331 INFO L290 TraceCheckUtils]: 84: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:33:40,331 INFO L290 TraceCheckUtils]: 83: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:33:40,331 INFO L290 TraceCheckUtils]: 82: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:33:40,331 INFO L272 TraceCheckUtils]: 81: Hoare triple {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:33:40,350 INFO L290 TraceCheckUtils]: 80: Hoare triple {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} assume !false; {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:33:40,369 INFO L290 TraceCheckUtils]: 79: Hoare triple {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} assume !(~r~0 >= ~d~0); {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:33:40,371 INFO L284 TraceCheckUtils]: 78: Hoare quadruple {19003#true} {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} #84#return; {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:33:40,371 INFO L290 TraceCheckUtils]: 77: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:33:40,371 INFO L290 TraceCheckUtils]: 76: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:33:40,371 INFO L290 TraceCheckUtils]: 75: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:33:40,372 INFO L272 TraceCheckUtils]: 74: Hoare triple {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:33:40,373 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {19003#true} {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} #82#return; {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:33:40,374 INFO L290 TraceCheckUtils]: 72: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:33:40,374 INFO L290 TraceCheckUtils]: 71: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:33:40,374 INFO L290 TraceCheckUtils]: 70: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:33:40,374 INFO L272 TraceCheckUtils]: 69: Hoare triple {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:33:40,376 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {19003#true} {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} #80#return; {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:33:40,376 INFO L290 TraceCheckUtils]: 67: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:33:40,376 INFO L290 TraceCheckUtils]: 66: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:33:40,376 INFO L290 TraceCheckUtils]: 65: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:33:40,376 INFO L272 TraceCheckUtils]: 64: Hoare triple {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:33:40,395 INFO L290 TraceCheckUtils]: 63: Hoare triple {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} assume !false; {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:33:40,640 INFO L290 TraceCheckUtils]: 62: Hoare triple {19579#(or (not (<= main_~d~0 main_~r~0)) (and (or (and (or (not (< (div main_~p~0 2) 0)) (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2) 1)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0))) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2)))) main_~A~0))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0))) (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (and (or (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 1))) main_~A~0)) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2)) main_~B~0) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0) main_~A~0) (not (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0)))))) (<= (+ main_~d~0 (div main_~d~0 2)) main_~r~0))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {19491#(and (or (and (or (not (< main_~p~0 0)) (= (mod main_~p~0 2) 0) (and (or (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0)) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0)) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= main_~A~0 (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))) (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0)))) (or (not (< (div main_~d~0 2) 0)) (and (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (and (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)))) (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))))))) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0)))) (or (and (or (not (< (div main_~d~0 2) 0)) (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2) 1) main_~r~0) (= (mod (div main_~d~0 2) 2) 0) (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0)) (or (= (+ main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2)))))) (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0) (and (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))))) (or (not (= (mod (+ (div (div main_~d~0 2) 2) 1) 2) 0)) (and (or (= (+ main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (div main_~d~0 2) 2) 1) 2))))))))))) (or (<= (+ (div (div main_~d~0 2) 2) (div main_~d~0 2)) main_~r~0) (and (< (div main_~d~0 2) 0) (not (= (mod (div main_~d~0 2) 2) 0))) (and (or (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (= (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1))) main_~A~0)) (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))) main_~A~0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (not (< (div (div main_~d~0 2) 2) 0)) (= (mod (div (div main_~d~0 2) 2) 2) 0) (and (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2))))) (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= main_~A~0 (+ (- 1) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)))) (not (< (div (div main_~p~0 2) 2) 0))))) (or (and (not (= (mod (div (div main_~d~0 2) 2) 2) 0)) (< (div (div main_~d~0 2) 2) 0)) (and (or (= (mod (div (div main_~p~0 2) 2) 2) 0) (= (+ (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2))) main_~A~0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) (* (div (div (div main_~d~0 2) 2) 2) (- 1)) main_~r~0 (* (- 1) (div main_~d~0 2)))))))))))) (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)))) (and (not (= (mod main_~d~0 2) 0)) (< main_~d~0 0))) (or (and (or (and (not (= (mod main_~p~0 2) 0)) (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (= (mod (div main_~p~0 2) 2) 0) (and (or (and (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (or (= (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (not (< (div main_~p~0 2) 0))) (or (and (or (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)))) (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)) (= main_~A~0 (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)))))))) (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (and (or (and (or (and (or (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0)) (= main_~A~0 (+ (- 1) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= main_~A~0 (+ (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2))) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* main_~B~0 (+ (div (+ (div (div main_~p~0 2) 2) 1) 2) main_~q~0 (div main_~p~0 2) 1)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (+ (div (div main_~p~0 2) 2) 1) 2) 0))))) (= (mod (div main_~p~0 2) 2) 0) (not (< (div main_~p~0 2) 0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div main_~p~0 2) 2) 0))) (and (or (and (or (= (+ (- 2) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 2) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0)))) (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (or (and (or (= main_~A~0 (+ (- 1) main_~r~0 (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (div main_~p~0 2) 2) 2) 0) (not (< (div (div main_~p~0 2) 2) 0))) (or (= (+ (- 1) (* (+ (div (div (div main_~p~0 2) 2) 2) main_~q~0 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (and (not (= (mod (div (div main_~p~0 2) 2) 2) 0)) (< (div (div main_~p~0 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0)))) (or (not (< main_~p~0 0)) (and (or (<= (+ 2 (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2)) main_~r~0) (and (or (and (or (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)) (or (and (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (or (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))) main_~A~0) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))) (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))))) (or (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2))) main_~A~0) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0))) (not (= (mod (+ (div (+ (div main_~d~0 2) 1) 2) 1) 2) 0)))))) (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (or (not (= 0 (mod (+ (div main_~d~0 2) 1) 2))) (and (or (= (mod (+ (div main_~p~0 2) 1) 2) 0) (and (or (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)) (and (or (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)) (= (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (- 1) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2))))) (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0)))) (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0) (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)) (* main_~B~0 (+ main_~q~0 2 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2)))))) (or (= main_~A~0 (+ (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (+ main_~q~0 (div (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) (div main_~p~0 2) 1) main_~B~0) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (not (= (mod (+ (div (+ (div main_~p~0 2) 1) 2) 1) 2) 0))))))) (or (not (= (mod (+ (div main_~p~0 2) 1) 2) 0)) (and (or (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0) (and (or (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (= (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0)) (or (= main_~A~0 (+ (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) (- 2) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (or (and (or (= main_~A~0 (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 2 (div main_~p~0 2)) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2)))) (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)) (or (= (+ (- 1) (* (+ (div (div (+ (div main_~p~0 2) 1) 2) 2) main_~q~0 (div main_~p~0 2) 1) main_~B~0) main_~r~0 (* (- 1) (div main_~d~0 2)) (* (- 1) (div (div (+ (div main_~d~0 2) 1) 2) 2))) main_~A~0) (not (= (mod (div (+ (div main_~p~0 2) 1) 2) 2) 0)))) (not (= (mod (div (+ (div main_~d~0 2) 1) 2) 2) 0)))))) (<= (+ (div (+ (div main_~d~0 2) 1) 2) (div main_~d~0 2) 1) main_~r~0))) (= (mod main_~p~0 2) 0))) (not (< main_~d~0 0)) (= (mod main_~d~0 2) 0)))} is VALID [2022-04-08 13:33:40,640 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {19003#true} {19579#(or (not (<= main_~d~0 main_~r~0)) (and (or (and (or (not (< (div main_~p~0 2) 0)) (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2) 1)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0))) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2)))) main_~A~0))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0))) (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (and (or (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 1))) main_~A~0)) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2)) main_~B~0) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0) main_~A~0) (not (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0)))))) (<= (+ main_~d~0 (div main_~d~0 2)) main_~r~0))} #84#return; {19579#(or (not (<= main_~d~0 main_~r~0)) (and (or (and (or (not (< (div main_~p~0 2) 0)) (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2) 1)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0))) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2)))) main_~A~0))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0))) (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (and (or (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 1))) main_~A~0)) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2)) main_~B~0) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0) main_~A~0) (not (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0)))))) (<= (+ main_~d~0 (div main_~d~0 2)) main_~r~0))} is VALID [2022-04-08 13:33:40,641 INFO L290 TraceCheckUtils]: 60: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:33:40,641 INFO L290 TraceCheckUtils]: 59: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:33:40,641 INFO L290 TraceCheckUtils]: 58: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:33:40,641 INFO L272 TraceCheckUtils]: 57: Hoare triple {19579#(or (not (<= main_~d~0 main_~r~0)) (and (or (and (or (not (< (div main_~p~0 2) 0)) (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2) 1)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0))) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2)))) main_~A~0))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0))) (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (and (or (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 1))) main_~A~0)) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2)) main_~B~0) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0) main_~A~0) (not (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0)))))) (<= (+ main_~d~0 (div main_~d~0 2)) main_~r~0))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:33:40,641 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {19003#true} {19579#(or (not (<= main_~d~0 main_~r~0)) (and (or (and (or (not (< (div main_~p~0 2) 0)) (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2) 1)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0))) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2)))) main_~A~0))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0))) (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (and (or (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 1))) main_~A~0)) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2)) main_~B~0) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0) main_~A~0) (not (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0)))))) (<= (+ main_~d~0 (div main_~d~0 2)) main_~r~0))} #82#return; {19579#(or (not (<= main_~d~0 main_~r~0)) (and (or (and (or (not (< (div main_~p~0 2) 0)) (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2) 1)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0))) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2)))) main_~A~0))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0))) (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (and (or (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 1))) main_~A~0)) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2)) main_~B~0) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0) main_~A~0) (not (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0)))))) (<= (+ main_~d~0 (div main_~d~0 2)) main_~r~0))} is VALID [2022-04-08 13:33:40,641 INFO L290 TraceCheckUtils]: 55: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:33:40,641 INFO L290 TraceCheckUtils]: 54: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:33:40,641 INFO L290 TraceCheckUtils]: 53: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:33:40,641 INFO L272 TraceCheckUtils]: 52: Hoare triple {19579#(or (not (<= main_~d~0 main_~r~0)) (and (or (and (or (not (< (div main_~p~0 2) 0)) (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2) 1)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0))) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2)))) main_~A~0))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0))) (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (and (or (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 1))) main_~A~0)) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2)) main_~B~0) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0) main_~A~0) (not (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0)))))) (<= (+ main_~d~0 (div main_~d~0 2)) main_~r~0))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:33:40,642 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {19003#true} {19579#(or (not (<= main_~d~0 main_~r~0)) (and (or (and (or (not (< (div main_~p~0 2) 0)) (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2) 1)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0))) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2)))) main_~A~0))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0))) (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (and (or (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 1))) main_~A~0)) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2)) main_~B~0) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0) main_~A~0) (not (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0)))))) (<= (+ main_~d~0 (div main_~d~0 2)) main_~r~0))} #80#return; {19579#(or (not (<= main_~d~0 main_~r~0)) (and (or (and (or (not (< (div main_~p~0 2) 0)) (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2) 1)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0))) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2)))) main_~A~0))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0))) (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (and (or (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 1))) main_~A~0)) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2)) main_~B~0) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0) main_~A~0) (not (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0)))))) (<= (+ main_~d~0 (div main_~d~0 2)) main_~r~0))} is VALID [2022-04-08 13:33:40,642 INFO L290 TraceCheckUtils]: 50: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:33:40,642 INFO L290 TraceCheckUtils]: 49: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:33:40,642 INFO L290 TraceCheckUtils]: 48: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:33:40,642 INFO L272 TraceCheckUtils]: 47: Hoare triple {19579#(or (not (<= main_~d~0 main_~r~0)) (and (or (and (or (not (< (div main_~p~0 2) 0)) (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2) 1)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0))) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2)))) main_~A~0))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0))) (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (and (or (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 1))) main_~A~0)) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2)) main_~B~0) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0) main_~A~0) (not (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0)))))) (<= (+ main_~d~0 (div main_~d~0 2)) main_~r~0))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:33:40,644 INFO L290 TraceCheckUtils]: 46: Hoare triple {19579#(or (not (<= main_~d~0 main_~r~0)) (and (or (and (or (not (< (div main_~p~0 2) 0)) (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2) 1)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0))) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2)))) main_~A~0))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0))) (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (and (or (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 1))) main_~A~0)) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2)) main_~B~0) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0) main_~A~0) (not (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0)))))) (<= (+ main_~d~0 (div main_~d~0 2)) main_~r~0))} assume !false; {19579#(or (not (<= main_~d~0 main_~r~0)) (and (or (and (or (not (< (div main_~p~0 2) 0)) (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2) 1)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0))) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2)))) main_~A~0))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0))) (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (and (or (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 1))) main_~A~0)) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2)) main_~B~0) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0) main_~A~0) (not (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0)))))) (<= (+ main_~d~0 (div main_~d~0 2)) main_~r~0))} is VALID [2022-04-08 13:33:40,662 INFO L290 TraceCheckUtils]: 45: Hoare triple {19631#(or (and (or (not (< main_~p~0 0)) (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (and (< main_~p~0 0) (not (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0))) (= (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0))) main_~A~0))) (not (<= (* main_~d~0 2) main_~r~0)) (<= (* main_~d~0 3) main_~r~0))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {19579#(or (not (<= main_~d~0 main_~r~0)) (and (or (and (or (not (< (div main_~p~0 2) 0)) (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 2) 2)) (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2) 1)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0))) (or (and (< (div main_~p~0 2) 0) (not (= (mod (div (div (* main_~p~0 2) 2) 2) 2) 0))) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (div (div (* main_~p~0 2) 2) 2) 2)))) main_~A~0))) (and (not (= (mod (div (* main_~p~0 2) 2) 2) 0)) (< main_~p~0 0))) (or (not (< main_~p~0 0)) (= (mod (div (* main_~p~0 2) 2) 2) 0) (and (or (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0) (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 1))) main_~A~0)) (or (= (+ (* (- 1) (div (* main_~d~0 2) 2)) (* (+ (div (* main_~p~0 2) 2) main_~q~0 (div (+ (div (div (* main_~p~0 2) 2) 2) 1) 2)) main_~B~0) (* (- 1) (div (div (div (* main_~d~0 2) 2) 2) 2)) main_~r~0) main_~A~0) (not (= (mod (+ (div (div (* main_~p~0 2) 2) 2) 1) 2) 0)))))) (<= (+ main_~d~0 (div main_~d~0 2)) main_~r~0))} is VALID [2022-04-08 13:33:40,663 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {19003#true} {19631#(or (and (or (not (< main_~p~0 0)) (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (and (< main_~p~0 0) (not (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0))) (= (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0))) main_~A~0))) (not (<= (* main_~d~0 2) main_~r~0)) (<= (* main_~d~0 3) main_~r~0))} #84#return; {19631#(or (and (or (not (< main_~p~0 0)) (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (and (< main_~p~0 0) (not (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0))) (= (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0))) main_~A~0))) (not (<= (* main_~d~0 2) main_~r~0)) (<= (* main_~d~0 3) main_~r~0))} is VALID [2022-04-08 13:33:40,663 INFO L290 TraceCheckUtils]: 43: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:33:40,663 INFO L290 TraceCheckUtils]: 42: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:33:40,663 INFO L290 TraceCheckUtils]: 41: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:33:40,663 INFO L272 TraceCheckUtils]: 40: Hoare triple {19631#(or (and (or (not (< main_~p~0 0)) (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (and (< main_~p~0 0) (not (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0))) (= (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0))) main_~A~0))) (not (<= (* main_~d~0 2) main_~r~0)) (<= (* main_~d~0 3) main_~r~0))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:33:40,664 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {19003#true} {19631#(or (and (or (not (< main_~p~0 0)) (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (and (< main_~p~0 0) (not (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0))) (= (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0))) main_~A~0))) (not (<= (* main_~d~0 2) main_~r~0)) (<= (* main_~d~0 3) main_~r~0))} #82#return; {19631#(or (and (or (not (< main_~p~0 0)) (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (and (< main_~p~0 0) (not (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0))) (= (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0))) main_~A~0))) (not (<= (* main_~d~0 2) main_~r~0)) (<= (* main_~d~0 3) main_~r~0))} is VALID [2022-04-08 13:33:40,664 INFO L290 TraceCheckUtils]: 38: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:33:40,664 INFO L290 TraceCheckUtils]: 37: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:33:40,664 INFO L290 TraceCheckUtils]: 36: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:33:40,664 INFO L272 TraceCheckUtils]: 35: Hoare triple {19631#(or (and (or (not (< main_~p~0 0)) (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (and (< main_~p~0 0) (not (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0))) (= (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0))) main_~A~0))) (not (<= (* main_~d~0 2) main_~r~0)) (<= (* main_~d~0 3) main_~r~0))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:33:40,664 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {19003#true} {19631#(or (and (or (not (< main_~p~0 0)) (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (and (< main_~p~0 0) (not (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0))) (= (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0))) main_~A~0))) (not (<= (* main_~d~0 2) main_~r~0)) (<= (* main_~d~0 3) main_~r~0))} #80#return; {19631#(or (and (or (not (< main_~p~0 0)) (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (and (< main_~p~0 0) (not (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0))) (= (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0))) main_~A~0))) (not (<= (* main_~d~0 2) main_~r~0)) (<= (* main_~d~0 3) main_~r~0))} is VALID [2022-04-08 13:33:40,664 INFO L290 TraceCheckUtils]: 33: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:33:40,665 INFO L290 TraceCheckUtils]: 32: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:33:40,665 INFO L290 TraceCheckUtils]: 31: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:33:40,665 INFO L272 TraceCheckUtils]: 30: Hoare triple {19631#(or (and (or (not (< main_~p~0 0)) (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (and (< main_~p~0 0) (not (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0))) (= (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0))) main_~A~0))) (not (<= (* main_~d~0 2) main_~r~0)) (<= (* main_~d~0 3) main_~r~0))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:33:40,666 INFO L290 TraceCheckUtils]: 29: Hoare triple {19631#(or (and (or (not (< main_~p~0 0)) (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (and (< main_~p~0 0) (not (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0))) (= (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0))) main_~A~0))) (not (<= (* main_~d~0 2) main_~r~0)) (<= (* main_~d~0 3) main_~r~0))} assume !false; {19631#(or (and (or (not (< main_~p~0 0)) (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (and (< main_~p~0 0) (not (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0))) (= (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0))) main_~A~0))) (not (<= (* main_~d~0 2) main_~r~0)) (<= (* main_~d~0 3) main_~r~0))} is VALID [2022-04-08 13:33:40,672 INFO L290 TraceCheckUtils]: 28: Hoare triple {19683#(or (<= (* main_~d~0 6) main_~r~0) (not (<= (* main_~d~0 4) main_~r~0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 8) 2)) (* (- 1) (div (div (div (* main_~d~0 8) 2) 2) 2)) main_~r~0 (* (+ (div (div (div (* main_~p~0 8) 2) 2) 2) (div (* main_~p~0 8) 2) main_~q~0) main_~B~0))))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {19631#(or (and (or (not (< main_~p~0 0)) (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0) (= main_~A~0 (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0 1) main_~B~0)))) (or (and (< main_~p~0 0) (not (= (mod (div (div (* main_~p~0 4) 2) 2) 2) 0))) (= (+ (* (- 1) (div (div (div (* main_~d~0 4) 2) 2) 2)) (* (- 1) (div (* main_~d~0 4) 2)) main_~r~0 (* main_~B~0 (+ (div (* main_~p~0 4) 2) (div (div (div (* main_~p~0 4) 2) 2) 2) main_~q~0))) main_~A~0))) (not (<= (* main_~d~0 2) main_~r~0)) (<= (* main_~d~0 3) main_~r~0))} is VALID [2022-04-08 13:33:40,673 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {19003#true} {19683#(or (<= (* main_~d~0 6) main_~r~0) (not (<= (* main_~d~0 4) main_~r~0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 8) 2)) (* (- 1) (div (div (div (* main_~d~0 8) 2) 2) 2)) main_~r~0 (* (+ (div (div (div (* main_~p~0 8) 2) 2) 2) (div (* main_~p~0 8) 2) main_~q~0) main_~B~0))))} #84#return; {19683#(or (<= (* main_~d~0 6) main_~r~0) (not (<= (* main_~d~0 4) main_~r~0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 8) 2)) (* (- 1) (div (div (div (* main_~d~0 8) 2) 2) 2)) main_~r~0 (* (+ (div (div (div (* main_~p~0 8) 2) 2) 2) (div (* main_~p~0 8) 2) main_~q~0) main_~B~0))))} is VALID [2022-04-08 13:33:40,673 INFO L290 TraceCheckUtils]: 26: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:33:40,673 INFO L290 TraceCheckUtils]: 25: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:33:40,673 INFO L290 TraceCheckUtils]: 24: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:33:40,673 INFO L272 TraceCheckUtils]: 23: Hoare triple {19683#(or (<= (* main_~d~0 6) main_~r~0) (not (<= (* main_~d~0 4) main_~r~0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 8) 2)) (* (- 1) (div (div (div (* main_~d~0 8) 2) 2) 2)) main_~r~0 (* (+ (div (div (div (* main_~p~0 8) 2) 2) 2) (div (* main_~p~0 8) 2) main_~q~0) main_~B~0))))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:33:40,674 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {19003#true} {19683#(or (<= (* main_~d~0 6) main_~r~0) (not (<= (* main_~d~0 4) main_~r~0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 8) 2)) (* (- 1) (div (div (div (* main_~d~0 8) 2) 2) 2)) main_~r~0 (* (+ (div (div (div (* main_~p~0 8) 2) 2) 2) (div (* main_~p~0 8) 2) main_~q~0) main_~B~0))))} #82#return; {19683#(or (<= (* main_~d~0 6) main_~r~0) (not (<= (* main_~d~0 4) main_~r~0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 8) 2)) (* (- 1) (div (div (div (* main_~d~0 8) 2) 2) 2)) main_~r~0 (* (+ (div (div (div (* main_~p~0 8) 2) 2) 2) (div (* main_~p~0 8) 2) main_~q~0) main_~B~0))))} is VALID [2022-04-08 13:33:40,674 INFO L290 TraceCheckUtils]: 21: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:33:40,674 INFO L290 TraceCheckUtils]: 20: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:33:40,674 INFO L290 TraceCheckUtils]: 19: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:33:40,674 INFO L272 TraceCheckUtils]: 18: Hoare triple {19683#(or (<= (* main_~d~0 6) main_~r~0) (not (<= (* main_~d~0 4) main_~r~0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 8) 2)) (* (- 1) (div (div (div (* main_~d~0 8) 2) 2) 2)) main_~r~0 (* (+ (div (div (div (* main_~p~0 8) 2) 2) 2) (div (* main_~p~0 8) 2) main_~q~0) main_~B~0))))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:33:40,675 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {19003#true} {19683#(or (<= (* main_~d~0 6) main_~r~0) (not (<= (* main_~d~0 4) main_~r~0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 8) 2)) (* (- 1) (div (div (div (* main_~d~0 8) 2) 2) 2)) main_~r~0 (* (+ (div (div (div (* main_~p~0 8) 2) 2) 2) (div (* main_~p~0 8) 2) main_~q~0) main_~B~0))))} #80#return; {19683#(or (<= (* main_~d~0 6) main_~r~0) (not (<= (* main_~d~0 4) main_~r~0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 8) 2)) (* (- 1) (div (div (div (* main_~d~0 8) 2) 2) 2)) main_~r~0 (* (+ (div (div (div (* main_~p~0 8) 2) 2) 2) (div (* main_~p~0 8) 2) main_~q~0) main_~B~0))))} is VALID [2022-04-08 13:33:40,675 INFO L290 TraceCheckUtils]: 16: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:33:40,675 INFO L290 TraceCheckUtils]: 15: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:33:40,675 INFO L290 TraceCheckUtils]: 14: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:33:40,675 INFO L272 TraceCheckUtils]: 13: Hoare triple {19683#(or (<= (* main_~d~0 6) main_~r~0) (not (<= (* main_~d~0 4) main_~r~0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 8) 2)) (* (- 1) (div (div (div (* main_~d~0 8) 2) 2) 2)) main_~r~0 (* (+ (div (div (div (* main_~p~0 8) 2) 2) 2) (div (* main_~p~0 8) 2) main_~q~0) main_~B~0))))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:33:40,675 INFO L290 TraceCheckUtils]: 12: Hoare triple {19683#(or (<= (* main_~d~0 6) main_~r~0) (not (<= (* main_~d~0 4) main_~r~0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 8) 2)) (* (- 1) (div (div (div (* main_~d~0 8) 2) 2) 2)) main_~r~0 (* (+ (div (div (div (* main_~p~0 8) 2) 2) 2) (div (* main_~p~0 8) 2) main_~q~0) main_~B~0))))} assume !false; {19683#(or (<= (* main_~d~0 6) main_~r~0) (not (<= (* main_~d~0 4) main_~r~0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 8) 2)) (* (- 1) (div (div (div (* main_~d~0 8) 2) 2) 2)) main_~r~0 (* (+ (div (div (div (* main_~p~0 8) 2) 2) 2) (div (* main_~p~0 8) 2) main_~q~0) main_~B~0))))} is VALID [2022-04-08 13:33:40,676 INFO L290 TraceCheckUtils]: 11: Hoare triple {19003#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {19683#(or (<= (* main_~d~0 6) main_~r~0) (not (<= (* main_~d~0 4) main_~r~0)) (= main_~A~0 (+ (* (- 1) (div (* main_~d~0 8) 2)) (* (- 1) (div (div (div (* main_~d~0 8) 2) 2) 2)) main_~r~0 (* (+ (div (div (div (* main_~p~0 8) 2) 2) 2) (div (* main_~p~0 8) 2) main_~q~0) main_~B~0))))} is VALID [2022-04-08 13:33:40,676 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {19003#true} {19003#true} #78#return; {19003#true} is VALID [2022-04-08 13:33:40,676 INFO L290 TraceCheckUtils]: 9: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:33:40,676 INFO L290 TraceCheckUtils]: 8: Hoare triple {19003#true} assume !(0 == ~cond); {19003#true} is VALID [2022-04-08 13:33:40,676 INFO L290 TraceCheckUtils]: 7: Hoare triple {19003#true} ~cond := #in~cond; {19003#true} is VALID [2022-04-08 13:33:40,676 INFO L272 TraceCheckUtils]: 6: Hoare triple {19003#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {19003#true} is VALID [2022-04-08 13:33:40,676 INFO L290 TraceCheckUtils]: 5: Hoare triple {19003#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {19003#true} is VALID [2022-04-08 13:33:40,676 INFO L272 TraceCheckUtils]: 4: Hoare triple {19003#true} call #t~ret5 := main(); {19003#true} is VALID [2022-04-08 13:33:40,676 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {19003#true} {19003#true} #94#return; {19003#true} is VALID [2022-04-08 13:33:40,676 INFO L290 TraceCheckUtils]: 2: Hoare triple {19003#true} assume true; {19003#true} is VALID [2022-04-08 13:33:40,676 INFO L290 TraceCheckUtils]: 1: Hoare triple {19003#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {19003#true} is VALID [2022-04-08 13:33:40,676 INFO L272 TraceCheckUtils]: 0: Hoare triple {19003#true} call ULTIMATE.init(); {19003#true} is VALID [2022-04-08 13:33:40,679 INFO L134 CoverageAnalysis]: Checked inductivity of 699 backedges. 36 proven. 51 refuted. 0 times theorem prover too weak. 612 trivial. 0 not checked. [2022-04-08 13:33:40,679 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-08 13:33:40,679 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [178590358] [2022-04-08 13:33:40,679 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-08 13:33:40,679 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [187213465] [2022-04-08 13:33:40,679 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [187213465] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-08 13:33:40,679 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-08 13:33:40,679 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [14, 14] total 24 [2022-04-08 13:33:40,680 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-08 13:33:40,680 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [511354882] [2022-04-08 13:33:40,680 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [511354882] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-08 13:33:40,680 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-08 13:33:40,680 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [14] imperfect sequences [] total 14 [2022-04-08 13:33:40,680 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1787054983] [2022-04-08 13:33:40,680 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-08 13:33:40,680 INFO L78 Accepts]: Start accepts. Automaton has has 14 states, 14 states have (on average 2.2142857142857144) internal successors, (31), 13 states have internal predecessors, (31), 8 states have call successors, (22), 2 states have call predecessors, (22), 1 states have return successors, (20), 7 states have call predecessors, (20), 7 states have call successors, (20) Word has length 124 [2022-04-08 13:33:40,680 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-08 13:33:40,681 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 14 states, 14 states have (on average 2.2142857142857144) internal successors, (31), 13 states have internal predecessors, (31), 8 states have call successors, (22), 2 states have call predecessors, (22), 1 states have return successors, (20), 7 states have call predecessors, (20), 7 states have call successors, (20) [2022-04-08 13:33:40,750 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 73 edges. 73 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:33:40,751 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 14 states [2022-04-08 13:33:40,751 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-08 13:33:40,751 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 14 interpolants. [2022-04-08 13:33:40,751 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=143, Invalid=409, Unknown=0, NotChecked=0, Total=552 [2022-04-08 13:33:40,751 INFO L87 Difference]: Start difference. First operand 184 states and 209 transitions. Second operand has 14 states, 14 states have (on average 2.2142857142857144) internal successors, (31), 13 states have internal predecessors, (31), 8 states have call successors, (22), 2 states have call predecessors, (22), 1 states have return successors, (20), 7 states have call predecessors, (20), 7 states have call successors, (20) [2022-04-08 13:33:42,962 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:33:42,962 INFO L93 Difference]: Finished difference Result 237 states and 276 transitions. [2022-04-08 13:33:42,962 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 14 states. [2022-04-08 13:33:42,963 INFO L78 Accepts]: Start accepts. Automaton has has 14 states, 14 states have (on average 2.2142857142857144) internal successors, (31), 13 states have internal predecessors, (31), 8 states have call successors, (22), 2 states have call predecessors, (22), 1 states have return successors, (20), 7 states have call predecessors, (20), 7 states have call successors, (20) Word has length 124 [2022-04-08 13:33:42,963 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-08 13:33:42,963 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 14 states, 14 states have (on average 2.2142857142857144) internal successors, (31), 13 states have internal predecessors, (31), 8 states have call successors, (22), 2 states have call predecessors, (22), 1 states have return successors, (20), 7 states have call predecessors, (20), 7 states have call successors, (20) [2022-04-08 13:33:42,964 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 14 states to 14 states and 137 transitions. [2022-04-08 13:33:42,964 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 14 states, 14 states have (on average 2.2142857142857144) internal successors, (31), 13 states have internal predecessors, (31), 8 states have call successors, (22), 2 states have call predecessors, (22), 1 states have return successors, (20), 7 states have call predecessors, (20), 7 states have call successors, (20) [2022-04-08 13:33:42,966 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 14 states to 14 states and 137 transitions. [2022-04-08 13:33:42,966 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 14 states and 137 transitions. [2022-04-08 13:33:43,114 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 137 edges. 137 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:33:43,117 INFO L225 Difference]: With dead ends: 237 [2022-04-08 13:33:43,117 INFO L226 Difference]: Without dead ends: 197 [2022-04-08 13:33:43,118 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 248 GetRequests, 224 SyntacticMatches, 1 SemanticMatches, 23 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 69 ImplicationChecksByTransitivity, 15.0s TimeCoverageRelationStatistics Valid=147, Invalid=453, Unknown=0, NotChecked=0, Total=600 [2022-04-08 13:33:43,118 INFO L913 BasicCegarLoop]: 63 mSDtfsCounter, 13 mSDsluCounter, 282 mSDsCounter, 0 mSdLazyCounter, 730 mSolverCounterSat, 26 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.8s Time, 0 mProtectedPredicate, 0 mProtectedAction, 19 SdHoareTripleChecker+Valid, 345 SdHoareTripleChecker+Invalid, 756 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 26 IncrementalHoareTripleChecker+Valid, 730 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.8s IncrementalHoareTripleChecker+Time [2022-04-08 13:33:43,118 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [19 Valid, 345 Invalid, 756 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [26 Valid, 730 Invalid, 0 Unknown, 0 Unchecked, 0.8s Time] [2022-04-08 13:33:43,119 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 197 states. [2022-04-08 13:33:43,307 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 197 to 184. [2022-04-08 13:33:43,307 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-08 13:33:43,308 INFO L82 GeneralOperation]: Start isEquivalent. First operand 197 states. Second operand has 184 states, 116 states have (on average 1.0948275862068966) internal successors, (127), 118 states have internal predecessors, (127), 42 states have call successors, (42), 26 states have call predecessors, (42), 25 states have return successors, (40), 39 states have call predecessors, (40), 40 states have call successors, (40) [2022-04-08 13:33:43,308 INFO L74 IsIncluded]: Start isIncluded. First operand 197 states. Second operand has 184 states, 116 states have (on average 1.0948275862068966) internal successors, (127), 118 states have internal predecessors, (127), 42 states have call successors, (42), 26 states have call predecessors, (42), 25 states have return successors, (40), 39 states have call predecessors, (40), 40 states have call successors, (40) [2022-04-08 13:33:43,308 INFO L87 Difference]: Start difference. First operand 197 states. Second operand has 184 states, 116 states have (on average 1.0948275862068966) internal successors, (127), 118 states have internal predecessors, (127), 42 states have call successors, (42), 26 states have call predecessors, (42), 25 states have return successors, (40), 39 states have call predecessors, (40), 40 states have call successors, (40) [2022-04-08 13:33:43,311 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:33:43,311 INFO L93 Difference]: Finished difference Result 197 states and 226 transitions. [2022-04-08 13:33:43,311 INFO L276 IsEmpty]: Start isEmpty. Operand 197 states and 226 transitions. [2022-04-08 13:33:43,311 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:33:43,312 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:33:43,312 INFO L74 IsIncluded]: Start isIncluded. First operand has 184 states, 116 states have (on average 1.0948275862068966) internal successors, (127), 118 states have internal predecessors, (127), 42 states have call successors, (42), 26 states have call predecessors, (42), 25 states have return successors, (40), 39 states have call predecessors, (40), 40 states have call successors, (40) Second operand 197 states. [2022-04-08 13:33:43,312 INFO L87 Difference]: Start difference. First operand has 184 states, 116 states have (on average 1.0948275862068966) internal successors, (127), 118 states have internal predecessors, (127), 42 states have call successors, (42), 26 states have call predecessors, (42), 25 states have return successors, (40), 39 states have call predecessors, (40), 40 states have call successors, (40) Second operand 197 states. [2022-04-08 13:33:43,315 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-08 13:33:43,315 INFO L93 Difference]: Finished difference Result 197 states and 226 transitions. [2022-04-08 13:33:43,315 INFO L276 IsEmpty]: Start isEmpty. Operand 197 states and 226 transitions. [2022-04-08 13:33:43,315 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-08 13:33:43,315 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-08 13:33:43,315 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-08 13:33:43,315 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-08 13:33:43,315 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 184 states, 116 states have (on average 1.0948275862068966) internal successors, (127), 118 states have internal predecessors, (127), 42 states have call successors, (42), 26 states have call predecessors, (42), 25 states have return successors, (40), 39 states have call predecessors, (40), 40 states have call successors, (40) [2022-04-08 13:33:43,318 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 184 states to 184 states and 209 transitions. [2022-04-08 13:33:43,318 INFO L78 Accepts]: Start accepts. Automaton has 184 states and 209 transitions. Word has length 124 [2022-04-08 13:33:43,318 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-08 13:33:43,318 INFO L478 AbstractCegarLoop]: Abstraction has 184 states and 209 transitions. [2022-04-08 13:33:43,319 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 14 states, 14 states have (on average 2.2142857142857144) internal successors, (31), 13 states have internal predecessors, (31), 8 states have call successors, (22), 2 states have call predecessors, (22), 1 states have return successors, (20), 7 states have call predecessors, (20), 7 states have call successors, (20) [2022-04-08 13:33:43,319 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 184 states and 209 transitions. [2022-04-08 13:33:43,653 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 209 edges. 209 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-08 13:33:43,653 INFO L276 IsEmpty]: Start isEmpty. Operand 184 states and 209 transitions. [2022-04-08 13:33:43,662 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 129 [2022-04-08 13:33:43,662 INFO L491 BasicCegarLoop]: Found error trace [2022-04-08 13:33:43,662 INFO L499 BasicCegarLoop]: trace histogram [20, 19, 19, 5, 5, 5, 5, 5, 5, 5, 4, 3, 3, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-08 13:33:43,678 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (17)] Forceful destruction successful, exit code 0 [2022-04-08 13:33:43,862 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable18,17 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:33:43,863 INFO L403 AbstractCegarLoop]: === Iteration 20 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-08 13:33:43,863 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-08 13:33:43,864 INFO L85 PathProgramCache]: Analyzing trace with hash -964214553, now seen corresponding path program 17 times [2022-04-08 13:33:43,864 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-08 13:33:43,864 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [1039199659] [2022-04-08 13:33:47,942 INFO L97 AcceleratorQvasr]: Qvasr could not accelerate loop because java.lang.UnsupportedOperationException: Cannot deal with arrays. [2022-04-08 13:33:47,942 INFO L274 tedInterpolationCore]: Could not compute an accelerate. [2022-04-08 13:33:47,942 INFO L85 PathProgramCache]: Analyzing trace with hash -964214553, now seen corresponding path program 18 times [2022-04-08 13:33:47,942 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-08 13:33:47,942 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [712605472] [2022-04-08 13:33:47,943 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-08 13:33:47,943 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-08 13:33:47,962 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-08 13:33:47,963 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1889811666] [2022-04-08 13:33:47,963 INFO L93 rtionOrderModulation]: Changing assertion order to MIX_INSIDE_OUTSIDE [2022-04-08 13:33:47,963 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-08 13:33:47,963 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-08 13:33:47,980 INFO L229 MonitoredProcess]: Starting monitored process 18 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-08 13:33:47,981 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (18)] Waiting until timeout for monitored process [2022-04-08 13:33:48,057 INFO L228 tOrderPrioritization]: Assert order MIX_INSIDE_OUTSIDE issued 7 check-sat command(s) [2022-04-08 13:33:48,057 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-08 13:33:48,059 INFO L263 TraceCheckSpWp]: Trace formula consists of 229 conjuncts, 50 conjunts are in the unsatisfiable core [2022-04-08 13:33:48,080 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-08 13:33:48,082 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-08 13:34:07,875 WARN L907 QuantifierPusher]: no eliminatee completely removed, nonetheless the elimination was considered successful [2022-04-08 13:34:09,858 WARN L907 QuantifierPusher]: no eliminatee completely removed, nonetheless the elimination was considered successful [2022-04-08 13:34:16,996 INFO L272 TraceCheckUtils]: 0: Hoare triple {21008#true} call ULTIMATE.init(); {21008#true} is VALID [2022-04-08 13:34:16,996 INFO L290 TraceCheckUtils]: 1: Hoare triple {21008#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(8, 2);call #Ultimate.allocInit(12, 3); {21008#true} is VALID [2022-04-08 13:34:16,996 INFO L290 TraceCheckUtils]: 2: Hoare triple {21008#true} assume true; {21008#true} is VALID [2022-04-08 13:34:16,996 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {21008#true} {21008#true} #94#return; {21008#true} is VALID [2022-04-08 13:34:16,996 INFO L272 TraceCheckUtils]: 4: Hoare triple {21008#true} call #t~ret5 := main(); {21008#true} is VALID [2022-04-08 13:34:16,996 INFO L290 TraceCheckUtils]: 5: Hoare triple {21008#true} havoc ~A~0;havoc ~B~0;havoc ~r~0;havoc ~d~0;havoc ~p~0;havoc ~q~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~A~0 := #t~nondet4;havoc #t~nondet4; {21008#true} is VALID [2022-04-08 13:34:16,996 INFO L272 TraceCheckUtils]: 6: Hoare triple {21008#true} call assume_abort_if_not((if ~A~0 >= 0 && ~A~0 <= 50 then 1 else 0)); {21008#true} is VALID [2022-04-08 13:34:16,996 INFO L290 TraceCheckUtils]: 7: Hoare triple {21008#true} ~cond := #in~cond; {21008#true} is VALID [2022-04-08 13:34:16,996 INFO L290 TraceCheckUtils]: 8: Hoare triple {21008#true} assume !(0 == ~cond); {21008#true} is VALID [2022-04-08 13:34:16,996 INFO L290 TraceCheckUtils]: 9: Hoare triple {21008#true} assume true; {21008#true} is VALID [2022-04-08 13:34:16,997 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {21008#true} {21008#true} #78#return; {21008#true} is VALID [2022-04-08 13:34:16,997 INFO L290 TraceCheckUtils]: 11: Hoare triple {21008#true} ~B~0 := 1;~r~0 := ~A~0;~d~0 := ~B~0;~p~0 := 1;~q~0 := 0; {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:34:16,997 INFO L290 TraceCheckUtils]: 12: Hoare triple {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} assume !false; {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:34:16,997 INFO L272 TraceCheckUtils]: 13: Hoare triple {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {21008#true} is VALID [2022-04-08 13:34:16,997 INFO L290 TraceCheckUtils]: 14: Hoare triple {21008#true} ~cond := #in~cond; {21008#true} is VALID [2022-04-08 13:34:16,997 INFO L290 TraceCheckUtils]: 15: Hoare triple {21008#true} assume !(0 == ~cond); {21008#true} is VALID [2022-04-08 13:34:16,997 INFO L290 TraceCheckUtils]: 16: Hoare triple {21008#true} assume true; {21008#true} is VALID [2022-04-08 13:34:16,998 INFO L284 TraceCheckUtils]: 17: Hoare quadruple {21008#true} {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} #80#return; {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:34:16,998 INFO L272 TraceCheckUtils]: 18: Hoare triple {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {21008#true} is VALID [2022-04-08 13:34:16,998 INFO L290 TraceCheckUtils]: 19: Hoare triple {21008#true} ~cond := #in~cond; {21008#true} is VALID [2022-04-08 13:34:16,998 INFO L290 TraceCheckUtils]: 20: Hoare triple {21008#true} assume !(0 == ~cond); {21008#true} is VALID [2022-04-08 13:34:16,998 INFO L290 TraceCheckUtils]: 21: Hoare triple {21008#true} assume true; {21008#true} is VALID [2022-04-08 13:34:16,998 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {21008#true} {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} #82#return; {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:34:16,998 INFO L272 TraceCheckUtils]: 23: Hoare triple {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {21008#true} is VALID [2022-04-08 13:34:16,999 INFO L290 TraceCheckUtils]: 24: Hoare triple {21008#true} ~cond := #in~cond; {21008#true} is VALID [2022-04-08 13:34:16,999 INFO L290 TraceCheckUtils]: 25: Hoare triple {21008#true} assume !(0 == ~cond); {21008#true} is VALID [2022-04-08 13:34:16,999 INFO L290 TraceCheckUtils]: 26: Hoare triple {21008#true} assume true; {21008#true} is VALID [2022-04-08 13:34:16,999 INFO L284 TraceCheckUtils]: 27: Hoare quadruple {21008#true} {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} #84#return; {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:34:16,999 INFO L290 TraceCheckUtils]: 28: Hoare triple {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:34:17,000 INFO L290 TraceCheckUtils]: 29: Hoare triple {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} assume !false; {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:34:17,000 INFO L272 TraceCheckUtils]: 30: Hoare triple {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {21008#true} is VALID [2022-04-08 13:34:17,000 INFO L290 TraceCheckUtils]: 31: Hoare triple {21008#true} ~cond := #in~cond; {21008#true} is VALID [2022-04-08 13:34:17,000 INFO L290 TraceCheckUtils]: 32: Hoare triple {21008#true} assume !(0 == ~cond); {21008#true} is VALID [2022-04-08 13:34:17,000 INFO L290 TraceCheckUtils]: 33: Hoare triple {21008#true} assume true; {21008#true} is VALID [2022-04-08 13:34:17,000 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {21008#true} {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} #80#return; {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:34:17,000 INFO L272 TraceCheckUtils]: 35: Hoare triple {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {21008#true} is VALID [2022-04-08 13:34:17,001 INFO L290 TraceCheckUtils]: 36: Hoare triple {21008#true} ~cond := #in~cond; {21008#true} is VALID [2022-04-08 13:34:17,001 INFO L290 TraceCheckUtils]: 37: Hoare triple {21008#true} assume !(0 == ~cond); {21008#true} is VALID [2022-04-08 13:34:17,001 INFO L290 TraceCheckUtils]: 38: Hoare triple {21008#true} assume true; {21008#true} is VALID [2022-04-08 13:34:17,001 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {21008#true} {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} #82#return; {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:34:17,001 INFO L272 TraceCheckUtils]: 40: Hoare triple {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {21008#true} is VALID [2022-04-08 13:34:17,001 INFO L290 TraceCheckUtils]: 41: Hoare triple {21008#true} ~cond := #in~cond; {21008#true} is VALID [2022-04-08 13:34:17,001 INFO L290 TraceCheckUtils]: 42: Hoare triple {21008#true} assume !(0 == ~cond); {21008#true} is VALID [2022-04-08 13:34:17,001 INFO L290 TraceCheckUtils]: 43: Hoare triple {21008#true} assume true; {21008#true} is VALID [2022-04-08 13:34:17,011 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {21008#true} {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} #84#return; {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:34:17,012 INFO L290 TraceCheckUtils]: 45: Hoare triple {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:34:17,012 INFO L290 TraceCheckUtils]: 46: Hoare triple {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} assume !false; {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:34:17,012 INFO L272 TraceCheckUtils]: 47: Hoare triple {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {21008#true} is VALID [2022-04-08 13:34:17,012 INFO L290 TraceCheckUtils]: 48: Hoare triple {21008#true} ~cond := #in~cond; {21008#true} is VALID [2022-04-08 13:34:17,013 INFO L290 TraceCheckUtils]: 49: Hoare triple {21008#true} assume !(0 == ~cond); {21008#true} is VALID [2022-04-08 13:34:17,013 INFO L290 TraceCheckUtils]: 50: Hoare triple {21008#true} assume true; {21008#true} is VALID [2022-04-08 13:34:17,013 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {21008#true} {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} #80#return; {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:34:17,013 INFO L272 TraceCheckUtils]: 52: Hoare triple {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {21008#true} is VALID [2022-04-08 13:34:17,013 INFO L290 TraceCheckUtils]: 53: Hoare triple {21008#true} ~cond := #in~cond; {21008#true} is VALID [2022-04-08 13:34:17,013 INFO L290 TraceCheckUtils]: 54: Hoare triple {21008#true} assume !(0 == ~cond); {21008#true} is VALID [2022-04-08 13:34:17,013 INFO L290 TraceCheckUtils]: 55: Hoare triple {21008#true} assume true; {21008#true} is VALID [2022-04-08 13:34:17,014 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {21008#true} {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} #82#return; {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:34:17,014 INFO L272 TraceCheckUtils]: 57: Hoare triple {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {21008#true} is VALID [2022-04-08 13:34:17,014 INFO L290 TraceCheckUtils]: 58: Hoare triple {21008#true} ~cond := #in~cond; {21008#true} is VALID [2022-04-08 13:34:17,014 INFO L290 TraceCheckUtils]: 59: Hoare triple {21008#true} assume !(0 == ~cond); {21008#true} is VALID [2022-04-08 13:34:17,014 INFO L290 TraceCheckUtils]: 60: Hoare triple {21008#true} assume true; {21008#true} is VALID [2022-04-08 13:34:17,014 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {21008#true} {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} #84#return; {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} is VALID [2022-04-08 13:34:17,016 INFO L290 TraceCheckUtils]: 62: Hoare triple {21046#(and (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {21200#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:34:17,016 INFO L290 TraceCheckUtils]: 63: Hoare triple {21200#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} assume !false; {21200#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:34:17,016 INFO L272 TraceCheckUtils]: 64: Hoare triple {21200#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {21008#true} is VALID [2022-04-08 13:34:17,016 INFO L290 TraceCheckUtils]: 65: Hoare triple {21008#true} ~cond := #in~cond; {21008#true} is VALID [2022-04-08 13:34:17,016 INFO L290 TraceCheckUtils]: 66: Hoare triple {21008#true} assume !(0 == ~cond); {21008#true} is VALID [2022-04-08 13:34:17,016 INFO L290 TraceCheckUtils]: 67: Hoare triple {21008#true} assume true; {21008#true} is VALID [2022-04-08 13:34:17,017 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {21008#true} {21200#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} #80#return; {21200#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:34:17,017 INFO L272 TraceCheckUtils]: 69: Hoare triple {21200#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {21008#true} is VALID [2022-04-08 13:34:17,017 INFO L290 TraceCheckUtils]: 70: Hoare triple {21008#true} ~cond := #in~cond; {21008#true} is VALID [2022-04-08 13:34:17,017 INFO L290 TraceCheckUtils]: 71: Hoare triple {21008#true} assume !(0 == ~cond); {21008#true} is VALID [2022-04-08 13:34:17,017 INFO L290 TraceCheckUtils]: 72: Hoare triple {21008#true} assume true; {21008#true} is VALID [2022-04-08 13:34:17,018 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {21008#true} {21200#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} #82#return; {21200#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:34:17,018 INFO L272 TraceCheckUtils]: 74: Hoare triple {21200#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {21008#true} is VALID [2022-04-08 13:34:17,018 INFO L290 TraceCheckUtils]: 75: Hoare triple {21008#true} ~cond := #in~cond; {21240#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:34:17,018 INFO L290 TraceCheckUtils]: 76: Hoare triple {21240#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {21244#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:34:17,019 INFO L290 TraceCheckUtils]: 77: Hoare triple {21244#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {21244#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:34:17,019 INFO L284 TraceCheckUtils]: 78: Hoare quadruple {21244#(not (= |__VERIFIER_assert_#in~cond| 0))} {21200#(and (= main_~A~0 main_~r~0) (= (mod main_~d~0 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} #84#return; {21251#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:34:17,021 INFO L290 TraceCheckUtils]: 79: Hoare triple {21251#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} assume !!(~r~0 >= ~d~0);~d~0 := 2 * ~d~0;~p~0 := 2 * ~p~0; {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:34:17,021 INFO L290 TraceCheckUtils]: 80: Hoare triple {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} assume !false; {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:34:17,021 INFO L272 TraceCheckUtils]: 81: Hoare triple {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} call __VERIFIER_assert((if 0 == ~q~0 then 1 else 0)); {21008#true} is VALID [2022-04-08 13:34:17,021 INFO L290 TraceCheckUtils]: 82: Hoare triple {21008#true} ~cond := #in~cond; {21008#true} is VALID [2022-04-08 13:34:17,021 INFO L290 TraceCheckUtils]: 83: Hoare triple {21008#true} assume !(0 == ~cond); {21008#true} is VALID [2022-04-08 13:34:17,021 INFO L290 TraceCheckUtils]: 84: Hoare triple {21008#true} assume true; {21008#true} is VALID [2022-04-08 13:34:17,022 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {21008#true} {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} #80#return; {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:34:17,022 INFO L272 TraceCheckUtils]: 86: Hoare triple {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} call __VERIFIER_assert((if ~r~0 == ~A~0 then 1 else 0)); {21008#true} is VALID [2022-04-08 13:34:17,022 INFO L290 TraceCheckUtils]: 87: Hoare triple {21008#true} ~cond := #in~cond; {21008#true} is VALID [2022-04-08 13:34:17,022 INFO L290 TraceCheckUtils]: 88: Hoare triple {21008#true} assume !(0 == ~cond); {21008#true} is VALID [2022-04-08 13:34:17,022 INFO L290 TraceCheckUtils]: 89: Hoare triple {21008#true} assume true; {21008#true} is VALID [2022-04-08 13:34:17,022 INFO L284 TraceCheckUtils]: 90: Hoare quadruple {21008#true} {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} #82#return; {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:34:17,023 INFO L272 TraceCheckUtils]: 91: Hoare triple {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {21008#true} is VALID [2022-04-08 13:34:17,023 INFO L290 TraceCheckUtils]: 92: Hoare triple {21008#true} ~cond := #in~cond; {21008#true} is VALID [2022-04-08 13:34:17,023 INFO L290 TraceCheckUtils]: 93: Hoare triple {21008#true} assume !(0 == ~cond); {21008#true} is VALID [2022-04-08 13:34:17,023 INFO L290 TraceCheckUtils]: 94: Hoare triple {21008#true} assume true; {21008#true} is VALID [2022-04-08 13:34:17,023 INFO L284 TraceCheckUtils]: 95: Hoare quadruple {21008#true} {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} #84#return; {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:34:17,024 INFO L290 TraceCheckUtils]: 96: Hoare triple {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} assume !(~r~0 >= ~d~0); {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:34:17,024 INFO L290 TraceCheckUtils]: 97: Hoare triple {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} assume !false; {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:34:17,024 INFO L272 TraceCheckUtils]: 98: Hoare triple {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {21008#true} is VALID [2022-04-08 13:34:17,024 INFO L290 TraceCheckUtils]: 99: Hoare triple {21008#true} ~cond := #in~cond; {21008#true} is VALID [2022-04-08 13:34:17,024 INFO L290 TraceCheckUtils]: 100: Hoare triple {21008#true} assume !(0 == ~cond); {21008#true} is VALID [2022-04-08 13:34:17,024 INFO L290 TraceCheckUtils]: 101: Hoare triple {21008#true} assume true; {21008#true} is VALID [2022-04-08 13:34:17,025 INFO L284 TraceCheckUtils]: 102: Hoare quadruple {21008#true} {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} #86#return; {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:34:17,025 INFO L272 TraceCheckUtils]: 103: Hoare triple {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {21008#true} is VALID [2022-04-08 13:34:17,025 INFO L290 TraceCheckUtils]: 104: Hoare triple {21008#true} ~cond := #in~cond; {21008#true} is VALID [2022-04-08 13:34:17,025 INFO L290 TraceCheckUtils]: 105: Hoare triple {21008#true} assume !(0 == ~cond); {21008#true} is VALID [2022-04-08 13:34:17,025 INFO L290 TraceCheckUtils]: 106: Hoare triple {21008#true} assume true; {21008#true} is VALID [2022-04-08 13:34:17,025 INFO L284 TraceCheckUtils]: 107: Hoare quadruple {21008#true} {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} #88#return; {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:34:17,029 INFO L290 TraceCheckUtils]: 108: Hoare triple {21255#(and (= (* 2 (* main_~B~0 (div main_~p~0 2))) main_~d~0) (= main_~A~0 main_~r~0) (= (mod (div main_~p~0 2) 2) 0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {21251#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:34:17,029 INFO L290 TraceCheckUtils]: 109: Hoare triple {21251#(and (= (* main_~B~0 main_~p~0) main_~d~0) (= main_~A~0 main_~r~0) (= main_~q~0 0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {21346#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= (* main_~B~0 main_~p~0) main_~d~0) (= (+ main_~d~0 main_~r~0) main_~A~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:34:17,030 INFO L290 TraceCheckUtils]: 110: Hoare triple {21346#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= (* main_~B~0 main_~p~0) main_~d~0) (= (+ main_~d~0 main_~r~0) main_~A~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} assume !false; {21346#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= (* main_~B~0 main_~p~0) main_~d~0) (= (+ main_~d~0 main_~r~0) main_~A~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:34:17,030 INFO L272 TraceCheckUtils]: 111: Hoare triple {21346#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= (* main_~B~0 main_~p~0) main_~d~0) (= (+ main_~d~0 main_~r~0) main_~A~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {21008#true} is VALID [2022-04-08 13:34:17,030 INFO L290 TraceCheckUtils]: 112: Hoare triple {21008#true} ~cond := #in~cond; {21240#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:34:17,030 INFO L290 TraceCheckUtils]: 113: Hoare triple {21240#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {21244#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:34:17,031 INFO L290 TraceCheckUtils]: 114: Hoare triple {21244#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {21244#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:34:17,031 INFO L284 TraceCheckUtils]: 115: Hoare quadruple {21244#(not (= |__VERIFIER_assert_#in~cond| 0))} {21346#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= (* main_~B~0 main_~p~0) main_~d~0) (= (+ main_~d~0 main_~r~0) main_~A~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} #86#return; {21346#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= (* main_~B~0 main_~p~0) main_~d~0) (= (+ main_~d~0 main_~r~0) main_~A~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:34:17,031 INFO L272 TraceCheckUtils]: 116: Hoare triple {21346#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= (* main_~B~0 main_~p~0) main_~d~0) (= (+ main_~d~0 main_~r~0) main_~A~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} call __VERIFIER_assert((if ~d~0 == ~B~0 * ~p~0 then 1 else 0)); {21008#true} is VALID [2022-04-08 13:34:17,031 INFO L290 TraceCheckUtils]: 117: Hoare triple {21008#true} ~cond := #in~cond; {21240#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:34:17,032 INFO L290 TraceCheckUtils]: 118: Hoare triple {21240#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {21244#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:34:17,032 INFO L290 TraceCheckUtils]: 119: Hoare triple {21244#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {21244#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-08 13:34:17,032 INFO L284 TraceCheckUtils]: 120: Hoare quadruple {21244#(not (= |__VERIFIER_assert_#in~cond| 0))} {21346#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= (* main_~B~0 main_~p~0) main_~d~0) (= (+ main_~d~0 main_~r~0) main_~A~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} #88#return; {21346#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= (* main_~B~0 main_~p~0) main_~d~0) (= (+ main_~d~0 main_~r~0) main_~A~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} is VALID [2022-04-08 13:34:17,035 INFO L290 TraceCheckUtils]: 121: Hoare triple {21346#(and (= (+ main_~q~0 (* (- 1) main_~p~0)) 0) (= (* main_~B~0 main_~p~0) main_~d~0) (= (+ main_~d~0 main_~r~0) main_~A~0) (= main_~B~0 1) (= (mod main_~p~0 2) 0))} assume !!(1 != ~p~0);~d~0 := (if ~d~0 < 0 && 0 != ~d~0 % 2 then 1 + ~d~0 / 2 else ~d~0 / 2);~p~0 := (if ~p~0 < 0 && 0 != ~p~0 % 2 then 1 + ~p~0 / 2 else ~p~0 / 2); {21383#(and (= main_~p~0 (div main_~q~0 2)) (= (+ main_~A~0 (* (- 1) main_~r~0)) (* main_~B~0 main_~q~0)) (= (div (+ main_~A~0 (* (- 1) main_~r~0)) 2) main_~d~0) (= (mod main_~q~0 2) 0) (= main_~B~0 1))} is VALID [2022-04-08 13:34:17,038 INFO L290 TraceCheckUtils]: 122: Hoare triple {21383#(and (= main_~p~0 (div main_~q~0 2)) (= (+ main_~A~0 (* (- 1) main_~r~0)) (* main_~B~0 main_~q~0)) (= (div (+ main_~A~0 (* (- 1) main_~r~0)) 2) main_~d~0) (= (mod main_~q~0 2) 0) (= main_~B~0 1))} assume ~r~0 >= ~d~0;~r~0 := ~r~0 - ~d~0;~q~0 := ~q~0 + ~p~0; {21387#(and (<= (* (div (+ (div (+ main_~r~0 (* (- 1) main_~A~0)) 3) (* main_~B~0 main_~q~0)) main_~B~0) 6) (* main_~q~0 4)) (= (mod (+ (* main_~A~0 2) (* main_~B~0 main_~q~0 3) main_~r~0) 3) 0) (< (* main_~q~0 4) (+ 2 (* (div (+ (div (+ main_~r~0 (* (- 1) main_~A~0)) 3) (* main_~B~0 main_~q~0)) main_~B~0) 6))) (= main_~B~0 1))} is VALID [2022-04-08 13:34:17,038 INFO L290 TraceCheckUtils]: 123: Hoare triple {21387#(and (<= (* (div (+ (div (+ main_~r~0 (* (- 1) main_~A~0)) 3) (* main_~B~0 main_~q~0)) main_~B~0) 6) (* main_~q~0 4)) (= (mod (+ (* main_~A~0 2) (* main_~B~0 main_~q~0 3) main_~r~0) 3) 0) (< (* main_~q~0 4) (+ 2 (* (div (+ (div (+ main_~r~0 (* (- 1) main_~A~0)) 3) (* main_~B~0 main_~q~0)) main_~B~0) 6))) (= main_~B~0 1))} assume !false; {21387#(and (<= (* (div (+ (div (+ main_~r~0 (* (- 1) main_~A~0)) 3) (* main_~B~0 main_~q~0)) main_~B~0) 6) (* main_~q~0 4)) (= (mod (+ (* main_~A~0 2) (* main_~B~0 main_~q~0 3) main_~r~0) 3) 0) (< (* main_~q~0 4) (+ 2 (* (div (+ (div (+ main_~r~0 (* (- 1) main_~A~0)) 3) (* main_~B~0 main_~q~0)) main_~B~0) 6))) (= main_~B~0 1))} is VALID [2022-04-08 13:34:17,041 INFO L272 TraceCheckUtils]: 124: Hoare triple {21387#(and (<= (* (div (+ (div (+ main_~r~0 (* (- 1) main_~A~0)) 3) (* main_~B~0 main_~q~0)) main_~B~0) 6) (* main_~q~0 4)) (= (mod (+ (* main_~A~0 2) (* main_~B~0 main_~q~0 3) main_~r~0) 3) 0) (< (* main_~q~0 4) (+ 2 (* (div (+ (div (+ main_~r~0 (* (- 1) main_~A~0)) 3) (* main_~B~0 main_~q~0)) main_~B~0) 6))) (= main_~B~0 1))} call __VERIFIER_assert((if ~A~0 == ~q~0 * ~B~0 + ~r~0 then 1 else 0)); {21394#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-08 13:34:17,041 INFO L290 TraceCheckUtils]: 125: Hoare triple {21394#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {21398#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-08 13:34:17,041 INFO L290 TraceCheckUtils]: 126: Hoare triple {21398#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {21009#false} is VALID [2022-04-08 13:34:17,041 INFO L290 TraceCheckUtils]: 127: Hoare triple {21009#false} assume !false; {21009#false} is VALID [2022-04-08 13:34:17,042 INFO L134 CoverageAnalysis]: Checked inductivity of 781 backedges. 199 proven. 27 refuted. 0 times theorem prover too weak. 555 trivial. 0 not checked. [2022-04-08 13:34:17,042 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-08 13:34:58,501 WARN L232 SmtUtils]: Spent 16.70s on a formula simplification that was a NOOP. DAG size: 50 (called from [L 360] de.uni_freiburg.informatik.ultimate.lib.modelcheckerutils.smt.predicates.PredicateUnifier.getOrConstructPredicate) [2022-04-08 13:37:36,390 WARN L232 SmtUtils]: Spent 9.34s on a formula simplification that was a NOOP. DAG size: 105 (called from [L 360] de.uni_freiburg.informatik.ultimate.lib.modelcheckerutils.smt.predicates.PredicateUnifier.getOrConstructPredicate)