// This file is part of the SV-Benchmarks collection of verification tasks: // https://gitlab.com/sosy-lab/benchmarking/sv-benchmarks // // SPDX-FileCopyrightText: 2001-2016 Daniel Kroening, Computer Science Department, University of Oxford // SPDX-FileCopyrightText: 2001-2016 Edmund Clarke, Computer Science Department, Carnegie Mellon University // SPDX-FileCopyrightText: 2014-2021 The SV-Benchmarks Community // // SPDX-License-Identifier: LicenseRef-BSD-4-Clause-Attribution-Kroening-Clarke extern void abort(void); #include void reach_error() { assert(0); } extern void abort(void); void assume_abort_if_not(int cond) { if(!cond) {abort();} } extern float __VERIFIER_nondet_float(void); #define NR 8 #if NR == 1 #define VAL 0.2f #elif NR == 2 #define VAL 0.4f #elif NR == 3 #define VAL 0.6f #elif NR == 4 #define VAL 0.8f #elif NR == 5 #define VAL 1.0f #elif NR == 6 #define VAL 1.2f #elif NR == 7 #define VAL 1.4f #elif NR == 8 #define VAL 2.0f #endif #define ITERATIONS 2 #if !(ITERATIONS >= 1 && ITERATIONS <= 3) #error Number of iterations must be between 1 and 3 #endif float f(float x) { return x - (x*x*x)/6.0f + (x*x*x*x*x)/120.0f + (x*x*x*x*x*x*x)/5040.0f; } float fp(float x) { return 1 - (x*x)/2.0f + (x*x*x*x)/24.0f + (x*x*x*x*x*x)/720.0f; } int main() { float IN = __VERIFIER_nondet_float(); assume_abort_if_not(IN > -VAL && IN < VAL); float x = IN - f(IN)/fp(IN); #if ITERATIONS > 1 x = x - f(x)/fp(x); #if ITERATIONS > 2 x = x - f(x)/fp(x); #endif #endif if(!(x < 0.1)) {reach_error();} return 0; }