Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / Orcas / SP / wpf / src / Shared / MS / Internal / FloatUtil.cs / 1 / FloatUtil.cs
//---------------------------------------------------------------------------- // // Copyright (C) Microsoft Corporation. All rights reserved. // // File: FloatUtil.cs // // Description: This file contains the implementation of FloatUtil, which // provides "fuzzy" comparison functionality for floats and // float-based classes and structs in our code. // // History: // 04/28/2003 : adsmith - Created this header // 05/20/2003 : adsmith - Move to Shared. // //--------------------------------------------------------------------------- using System; namespace MS.Internal { internal static class FloatUtil { internal static float FLT_EPSILON = 1.192092896e-07F; internal static float FLT_MAX_PRECISION = 0xffffff; internal static float INVERSE_FLT_MAX_PRECISION = 1.0F / FLT_MAX_PRECISION; ////// AreClose /// public static bool AreClose(float a, float b) { if(a == b) return true; // This computes (|a-b| / (|a| + |b| + 10.0f)) < FLT_EPSILON float eps = ((float)Math.Abs(a) + (float)Math.Abs(b) + 10.0f) * FLT_EPSILON; float delta = a - b; return(-eps < delta) && (eps > delta); } ////// IsOne /// public static bool IsOne(float a) { return (float)Math.Abs(a-1.0f) < 10.0f * FLT_EPSILON; } ////// IsZero /// public static bool IsZero(float a) { return (float)Math.Abs(a) < 10.0f * FLT_EPSILON; } ////// IsCloseToDivideByZero /// public static bool IsCloseToDivideByZero(float numerator, float denominator) { // When updating this, please also update code in Arithmetic.h return Math.Abs(denominator) <= Math.Abs(numerator) * INVERSE_FLT_MAX_PRECISION; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //---------------------------------------------------------------------------- // // Copyright (C) Microsoft Corporation. All rights reserved. // // File: FloatUtil.cs // // Description: This file contains the implementation of FloatUtil, which // provides "fuzzy" comparison functionality for floats and // float-based classes and structs in our code. // // History: // 04/28/2003 : adsmith - Created this header // 05/20/2003 : adsmith - Move to Shared. // //--------------------------------------------------------------------------- using System; namespace MS.Internal { internal static class FloatUtil { internal static float FLT_EPSILON = 1.192092896e-07F; internal static float FLT_MAX_PRECISION = 0xffffff; internal static float INVERSE_FLT_MAX_PRECISION = 1.0F / FLT_MAX_PRECISION; ////// AreClose /// public static bool AreClose(float a, float b) { if(a == b) return true; // This computes (|a-b| / (|a| + |b| + 10.0f)) < FLT_EPSILON float eps = ((float)Math.Abs(a) + (float)Math.Abs(b) + 10.0f) * FLT_EPSILON; float delta = a - b; return(-eps < delta) && (eps > delta); } ////// IsOne /// public static bool IsOne(float a) { return (float)Math.Abs(a-1.0f) < 10.0f * FLT_EPSILON; } ////// IsZero /// public static bool IsZero(float a) { return (float)Math.Abs(a) < 10.0f * FLT_EPSILON; } ////// IsCloseToDivideByZero /// public static bool IsCloseToDivideByZero(float numerator, float denominator) { // When updating this, please also update code in Arithmetic.h return Math.Abs(denominator) <= Math.Abs(numerator) * INVERSE_FLT_MAX_PRECISION; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- ConfigurationLockCollection.cs
- AssignDesigner.xaml.cs
- Track.cs
- ChildDocumentBlock.cs
- CustomLineCap.cs
- FormsAuthentication.cs
- WindowsListViewItemCheckBox.cs
- StoreContentChangedEventArgs.cs
- DriveInfo.cs
- DispatcherFrame.cs
- DurableErrorHandler.cs
- ContextStaticAttribute.cs
- LinqDataSourceView.cs
- AlternationConverter.cs
- ConcatQueryOperator.cs
- Boolean.cs
- TextBoxDesigner.cs
- CachedCompositeFamily.cs
- CodeNamespaceImport.cs
- DBAsyncResult.cs
- AttributeProviderAttribute.cs
- XmlSerializerVersionAttribute.cs
- RuntimeEnvironment.cs
- BulletChrome.cs
- EditableRegion.cs
- InputScopeConverter.cs
- CodeArgumentReferenceExpression.cs
- CacheDependency.cs
- DrawToolTipEventArgs.cs
- ExecutionContext.cs
- VisualBasicSettingsConverter.cs
- HtmlShimManager.cs
- WSMessageEncoding.cs
- SystemParameters.cs
- ListItemCollection.cs
- ObservableCollectionDefaultValueFactory.cs
- XamlParser.cs
- DesignTimeResourceProviderFactoryAttribute.cs
- GetIsBrowserClientRequest.cs
- GridSplitter.cs
- HtmlInputFile.cs
- PropertyKey.cs
- RegexStringValidator.cs
- Color.cs
- ArrayTypeMismatchException.cs
- LockCookie.cs
- InputLanguageProfileNotifySink.cs
- XmlAttributeAttribute.cs
- MessageLoggingFilterTraceRecord.cs
- TimeZoneNotFoundException.cs
- KnownBoxes.cs
- DiscoveryReferences.cs
- WebConvert.cs
- LineUtil.cs
- Positioning.cs
- LockedAssemblyCache.cs
- DataGridDetailsPresenterAutomationPeer.cs
- BindingCompleteEventArgs.cs
- ReferenceEqualityComparer.cs
- BoundPropertyEntry.cs
- StringPropertyBuilder.cs
- CommonEndpointBehaviorElement.cs
- NegotiateStream.cs
- OleDbConnectionInternal.cs
- DynamicObject.cs
- BooleanExpr.cs
- Animatable.cs
- ConnectionManagementSection.cs
- FieldInfo.cs
- ClientTarget.cs
- SchemaTableOptionalColumn.cs
- webclient.cs
- WindowsProgressbar.cs
- DiscoveryClientChannelBase.cs
- FtpRequestCacheValidator.cs
- keycontainerpermission.cs
- ViewLoader.cs
- EntityViewGenerationAttribute.cs
- HttpModulesSection.cs
- _WinHttpWebProxyDataBuilder.cs
- JsonFormatReaderGenerator.cs
- ClrPerspective.cs
- listviewsubitemcollectioneditor.cs
- CqlBlock.cs
- StructuralObject.cs
- SqlInfoMessageEvent.cs
- Int16Storage.cs
- Misc.cs
- SqlDelegatedTransaction.cs
- InstanceDataCollection.cs
- WebBrowserContainer.cs
- SqlDependency.cs
- CodeMethodReturnStatement.cs
- SvcMapFileSerializer.cs
- ViewStateChangedEventArgs.cs
- DrawTreeNodeEventArgs.cs
- LocalizableResourceBuilder.cs
- SessionParameter.cs
- SchemaDeclBase.cs
- IntSecurity.cs