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
- PathTooLongException.cs
- DataGridViewLayoutData.cs
- PackagePart.cs
- CallbackDebugElement.cs
- DetailsViewDeletedEventArgs.cs
- RadioButton.cs
- X500Name.cs
- CombinedGeometry.cs
- HGlobalSafeHandle.cs
- TokenBasedSet.cs
- TargetPerspective.cs
- OpenTypeCommon.cs
- SQLMembershipProvider.cs
- ContextMarshalException.cs
- ZipIOBlockManager.cs
- EventPrivateKey.cs
- SqlDataSourceView.cs
- DataObjectPastingEventArgs.cs
- HostProtectionPermission.cs
- HighContrastHelper.cs
- GeneralTransform2DTo3D.cs
- KerberosTicketHashIdentifierClause.cs
- WindowsPen.cs
- MetabaseSettingsIis7.cs
- LogSwitch.cs
- ClosableStream.cs
- TdsParserStaticMethods.cs
- DisplayMemberTemplateSelector.cs
- MgmtConfigurationRecord.cs
- BamlWriter.cs
- EntitySqlQueryState.cs
- Int32CollectionConverter.cs
- Wildcard.cs
- RequestDescription.cs
- x509store.cs
- MasterPageParser.cs
- ExceptionUtil.cs
- sqlcontext.cs
- ModifierKeysConverter.cs
- ByteConverter.cs
- FileSystemInfo.cs
- X509ChainElement.cs
- InstanceData.cs
- BatchStream.cs
- RSAPKCS1SignatureFormatter.cs
- Primitive.cs
- WindowsFormsSectionHandler.cs
- ClockController.cs
- WebBrowserDocumentCompletedEventHandler.cs
- BufferBuilder.cs
- DataBoundControlAdapter.cs
- UInt64Storage.cs
- TextEndOfLine.cs
- ConfigurationStrings.cs
- XmlCharacterData.cs
- NativeMethods.cs
- XmlSignificantWhitespace.cs
- SqlDataSourceConfigureSortForm.cs
- CounterSetInstanceCounterDataSet.cs
- InvalidOperationException.cs
- ChangeConflicts.cs
- DatagridviewDisplayedBandsData.cs
- SqlWriter.cs
- LicenseContext.cs
- ProcessingInstructionAction.cs
- IntegerValidator.cs
- NotFiniteNumberException.cs
- FixedTextPointer.cs
- FigureParagraph.cs
- DoWorkEventArgs.cs
- documentation.cs
- UriWriter.cs
- PowerStatus.cs
- PagerSettings.cs
- PrintEvent.cs
- DependencyObjectProvider.cs
- CompletionBookmark.cs
- ExpressionConverter.cs
- TextModifierScope.cs
- LambdaCompiler.cs
- StringFunctions.cs
- FileNotFoundException.cs
- Empty.cs
- GridViewHeaderRowPresenter.cs
- PageSettings.cs
- TextEditorMouse.cs
- ProfileManager.cs
- DataSourceControl.cs
- SqlDesignerDataSourceView.cs
- AxDesigner.cs
- ChannelBuilder.cs
- UnicastIPAddressInformationCollection.cs
- CryptoConfig.cs
- NativeMethods.cs
- FeatureSupport.cs
- SchemaSetCompiler.cs
- DetailsViewCommandEventArgs.cs
- DataGrid.cs
- MeasureData.cs
- TrustLevelCollection.cs