Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / Orcas / NetFXw7 / 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
- DictionaryGlobals.cs
- SignatureHelper.cs
- TreeView.cs
- XmlILStorageConverter.cs
- ProxyFragment.cs
- coordinatorscratchpad.cs
- ToolStripScrollButton.cs
- SHA384Managed.cs
- Token.cs
- DbExpressionVisitor_TResultType.cs
- WebConfigManager.cs
- WebServiceClientProxyGenerator.cs
- VarInfo.cs
- ExceptionUtil.cs
- AspCompat.cs
- DBSchemaRow.cs
- cookieexception.cs
- EditBehavior.cs
- KeyFrames.cs
- MissingManifestResourceException.cs
- SchemaElementLookUpTable.cs
- DefaultMemberAttribute.cs
- DataControlPagerLinkButton.cs
- ExceptionTranslationTable.cs
- EntityContainer.cs
- PixelShader.cs
- OleDbConnection.cs
- PolicyUnit.cs
- ProfileService.cs
- BinaryExpressionHelper.cs
- MethodImplAttribute.cs
- HttpSessionStateWrapper.cs
- EncryptedKeyIdentifierClause.cs
- ApplicationDirectory.cs
- pingexception.cs
- DrawListViewItemEventArgs.cs
- Table.cs
- PerfProviderCollection.cs
- RedirectionProxy.cs
- DataGridViewRowCollection.cs
- ZipIOExtraField.cs
- TrackingProfileCache.cs
- WebHttpBindingCollectionElement.cs
- SchemaEntity.cs
- DesignerWidgets.cs
- PropertyMap.cs
- FormViewInsertedEventArgs.cs
- ProxyWebPartManager.cs
- WeakEventTable.cs
- MediaCommands.cs
- HelpKeywordAttribute.cs
- FigureHelper.cs
- BaseParagraph.cs
- DelimitedListTraceListener.cs
- BorderGapMaskConverter.cs
- FontFaceLayoutInfo.cs
- Path.cs
- DataGridViewColumnConverter.cs
- SortKey.cs
- TextStore.cs
- linebase.cs
- CompiledQueryCacheKey.cs
- ReadWriteSpinLock.cs
- LinkLabelLinkClickedEvent.cs
- EventMap.cs
- ChangePasswordDesigner.cs
- DependencyPropertyKey.cs
- DataServiceQueryProvider.cs
- PathParser.cs
- MetadataArtifactLoader.cs
- ControlCachePolicy.cs
- CodeTypeMemberCollection.cs
- BinaryObjectReader.cs
- DesignerActionMethodItem.cs
- HuffModule.cs
- TraceInternal.cs
- XmlHelper.cs
- DataGridViewTopRowAccessibleObject.cs
- SchemaTableColumn.cs
- PrivateFontCollection.cs
- SqlDataSource.cs
- InternalSafeNativeMethods.cs
- DelegatingTypeDescriptionProvider.cs
- ISAPIRuntime.cs
- ToolStripItemImageRenderEventArgs.cs
- TextHintingModeValidation.cs
- SqlMetaData.cs
- IssuanceLicense.cs
- ImagingCache.cs
- FontConverter.cs
- RenderContext.cs
- TextDecorationCollection.cs
- PowerModeChangedEventArgs.cs
- CompressionTransform.cs
- Update.cs
- View.cs
- TileBrush.cs
- DateTimeConverter2.cs
- ProfileManager.cs
- NotificationContext.cs