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

z3-z3-4.13.0.src.math.lp.lp_settings_def.h Maven / Gradle / Ivy

The newest version!
/*++
Copyright (c) 2017 Microsoft Corporation

Module Name:

    

Abstract:

    

Author:

    Lev Nachmanson (levnach)

Revision History:


--*/
#pragma once

#include 
#include 
#include "util/vector.h"
#include "math/lp/lp_settings.h"
namespace lp {
std::string column_type_to_string(column_type t) {
    switch (t) {
    case column_type::fixed:       return "fixed";
    case column_type::boxed:       return "boxed";
    case column_type::lower_bound:   return "lower_bound";
    case column_type::upper_bound: return "upper_bound";
    case column_type::free_column: return "free_column";
    default:  UNREACHABLE();
    }
    return "unknown"; // it is unreachable
}

const char* lp_status_to_string(lp_status status) {
    switch (status) {
    case lp_status::UNKNOWN: return "UNKNOWN";
    case lp_status::INFEASIBLE: return "INFEASIBLE";
    case lp_status::UNBOUNDED: return "UNBOUNDED";
    case lp_status::TENTATIVE_DUAL_UNBOUNDED: return "TENTATIVE_DUAL_UNBOUNDED";
    case lp_status::DUAL_UNBOUNDED: return "DUAL_UNBOUNDED";
    case lp_status::OPTIMAL: return "OPTIMAL";
    case lp_status::FEASIBLE: return "FEASIBLE";
    case lp_status::TIME_EXHAUSTED: return "TIME_EXHAUSTED";
    case lp_status::EMPTY: return "EMPTY";
    case lp_status::UNSTABLE: return "UNSTABLE";
    case lp_status::CANCELLED: return "CANCELLED";
    default:
        UNREACHABLE();
    }
    return "UNKNOWN";  // it is unreachable
}

lp_status lp_status_from_string(std::string status) {
    if (status == "UNKNOWN") return  lp_status::UNKNOWN;
    if (status == "INFEASIBLE") return lp_status::INFEASIBLE;
    if (status == "UNBOUNDED") return lp_status::UNBOUNDED;
    if (status == "OPTIMAL") return lp_status::OPTIMAL;
    if (status == "FEASIBLE") return lp_status::FEASIBLE;
    if (status == "TIME_EXHAUSTED") return lp_status::TIME_EXHAUSTED;
    if (status == "EMPTY") return lp_status::EMPTY;
    UNREACHABLE();
    return lp_status::UNKNOWN; // it is unreachable
}


template 
bool vectors_are_equal(T * a, vector  &b, unsigned n) {
        for (unsigned i = 0; i < n; i ++){
            if (!numeric_traits::is_zero(a[i] - b[i])) {
                return false;
            }
        }
    
    return true;
}


template 
bool vectors_are_equal(const vector & a, const vector  &b) {
    unsigned n = static_cast(a.size());
    if (n != b.size()) return false;
        for (unsigned i = 0; i < n; i ++){
            if (!numeric_traits::is_zero(a[i] - b[i])) {
                return false;
            }
        }
    
    return true;
}
#ifdef Z3DEBUG
unsigned lp_settings::ddd = 0;
#endif
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy