Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Shared / MS / Internal / FloatUtil.cs / 1305600 / 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 : [....] - Created this header // 05/20/2003 : [....] - 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 : [....] - Created this header // 05/20/2003 : [....] - 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
- UniqueIdentifierService.cs
- ImageDesigner.cs
- UnsafeNativeMethods.cs
- FormsAuthenticationModule.cs
- XsltInput.cs
- DataGridViewIntLinkedList.cs
- TypedServiceOperationListItem.cs
- DataColumnMapping.cs
- ErrorWebPart.cs
- FileLoadException.cs
- EqualityComparer.cs
- PreviewControlDesigner.cs
- Request.cs
- SqlEnums.cs
- oledbmetadatacolumnnames.cs
- __Filters.cs
- WebBrowserNavigatingEventHandler.cs
- localization.cs
- DemultiplexingClientMessageFormatter.cs
- ColorConverter.cs
- Column.cs
- RuntimeWrappedException.cs
- ContainerUtilities.cs
- XmlTextReaderImplHelpers.cs
- Underline.cs
- PtsHost.cs
- WmlImageAdapter.cs
- StringUtil.cs
- DesignerDataSchemaClass.cs
- CodeDirectoryCompiler.cs
- JsonDeserializer.cs
- SecurityContextSecurityTokenResolver.cs
- SiteMapNode.cs
- BaseTransportHeaders.cs
- DataGridViewCellLinkedList.cs
- COM2ExtendedBrowsingHandler.cs
- UpDownBase.cs
- contentDescriptor.cs
- WaitForChangedResult.cs
- EntityContainer.cs
- MultiSelectRootGridEntry.cs
- HostingEnvironment.cs
- IndependentAnimationStorage.cs
- LicenseManager.cs
- ChannelOptions.cs
- NotifyInputEventArgs.cs
- EnumerableWrapperWeakToStrong.cs
- TextDecorationLocationValidation.cs
- ZipPackage.cs
- PropertyEmitter.cs
- PriorityQueue.cs
- SystemUnicastIPAddressInformation.cs
- XmlNodeChangedEventArgs.cs
- Item.cs
- RowUpdatedEventArgs.cs
- sortedlist.cs
- CodeAttributeArgumentCollection.cs
- XmlILOptimizerVisitor.cs
- CodeAccessPermission.cs
- TileModeValidation.cs
- RelatedImageListAttribute.cs
- _PooledStream.cs
- FloaterBaseParaClient.cs
- WindowsImpersonationContext.cs
- StrokeNodeOperations.cs
- WebPartsPersonalizationAuthorization.cs
- COM2PropertyDescriptor.cs
- AccessedThroughPropertyAttribute.cs
- NativeRightsManagementAPIsStructures.cs
- BaseTemplateCodeDomTreeGenerator.cs
- SQLChars.cs
- SByte.cs
- Add.cs
- DataStreamFromComStream.cs
- _PooledStream.cs
- DBSchemaRow.cs
- SqlCommandAsyncResult.cs
- UnicodeEncoding.cs
- ToolStripCollectionEditor.cs
- HeaderFilter.cs
- LogArchiveSnapshot.cs
- GlyphTypeface.cs
- XamlVector3DCollectionSerializer.cs
- BinHexEncoder.cs
- SqlReorderer.cs
- SiteMapProvider.cs
- BitmapEffectInput.cs
- XPathSelectionIterator.cs
- DoubleLink.cs
- GeneralTransformGroup.cs
- GAC.cs
- ConfigurationManagerInternalFactory.cs
- VisualStyleTypesAndProperties.cs
- SignalGate.cs
- safex509handles.cs
- TextWriter.cs
- Animatable.cs
- NetworkInformationPermission.cs
- TemplateComponentConnector.cs
- WebServiceHostFactory.cs