// // IntervalRationalAssumerBase.cs // // Authors: // Alexander Chebaturkin (chebaturkin@gmail.com) // // Copyright (C) 2012 Alexander Chebaturkin // // Permission is hereby granted, free of charge, to any person obtaining // a copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to // permit persons to whom the Software is furnished to do so, subject to // the following conditions: // // The above copyright notice and this permission notice shall be // included in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. // using System; using Mono.CodeContracts.Static.DataStructures; namespace Mono.CodeContracts.Static.Analysis.Numerical { abstract class IntervalRationalAssumerBase : IntervalAssumerBase where TInterval : IntervalBase where TVar : IEquatable { public override IntervalEnvironmentBase AssumeLessThan (TExpr left, TExpr right, IntervalEnvironmentBase env) { bool isBottom; var constraints = IntervalInference.ConstraintsFor.LessThan, TVar, TExpr, TInterval> (left, right, env.Decoder, env, out isBottom); if (isBottom) return env.Bottom; var res = env; foreach (var v in constraints.Keys) { var intervals = constraints[v].AsEnumerable (); foreach (var intv in intervals) res = res.RefineVariable (v, intv); } return res; } public override IntervalEnvironmentBase AssumeLessEqualThan (TExpr left, TExpr right, IntervalEnvironmentBase env) { bool isBottom; var constraints = IntervalInference.ConstraintsFor.LessEqualThan , TVar, TExpr, TInterval> (left, right, env.Decoder, env, out isBottom); if (isBottom) return env.Bottom; return AssumeConstraints (constraints, env); } public override IntervalEnvironmentBase AssumeGreaterEqualThanZero (TExpr expr, IntervalEnvironmentBase env) { var constraints = IntervalInference.ConstraintsFor.GreaterEqualThanZero , TVar, TExpr, TInterval> (expr, env.Decoder, env); return AssumeConstraints (constraints, env); } public override IntervalEnvironmentBase AssumeLessThan (TInterval intv, TVar right, IntervalEnvironmentBase env) { TInterval refined; if ( !IntervalInference.ConstraintsFor.TryRefineLessEqualThan , TVar, TExpr, TInterval> (intv, right, env, out refined)) return env; return env.With (right, refined); } public override IntervalEnvironmentBase AssumeLessEqualThan ( TInterval intv, TVar right, IntervalEnvironmentBase env) { TInterval refined; if ( !IntervalInference.ConstraintsFor.TryRefineLessEqualThan , TVar, TExpr, TInterval> (intv, right, env, out refined)) return env; return env.With (right, refined); } public override IntervalEnvironmentBase AssumeNotEqualToZero (TExpr e, IntervalEnvironmentBase < TVar , TExpr , TInterval , Rational > env) { var variable = env.Decoder.UnderlyingVariable (e); var intv = env.Eval (e); TInterval refinement; if (intv.LowerBound.IsZero) refinement = env.Context.For (1L, intv.UpperBound); else if (intv.UpperBound.IsZero) refinement = env.Context.For (intv.LowerBound, -1L); else refinement = env.Context.TopValue; return env.With (variable, intv.Meet (refinement)); } } }