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
- XmlDataDocument.cs
- TextEditorLists.cs
- XsltException.cs
- FunctionDetailsReader.cs
- SamlAuthorityBinding.cs
- ConnectionPoolManager.cs
- regiisutil.cs
- ProtocolException.cs
- Normalizer.cs
- EventProviderTraceListener.cs
- CompilationRelaxations.cs
- ColumnHeader.cs
- ToolboxItemSnapLineBehavior.cs
- EncoderParameter.cs
- TextRangeSerialization.cs
- _ListenerAsyncResult.cs
- UpdateProgress.cs
- Pool.cs
- SafeRegistryHandle.cs
- CompilationUtil.cs
- DPCustomTypeDescriptor.cs
- SqlCacheDependencyDatabaseCollection.cs
- SqlDataReaderSmi.cs
- Geometry.cs
- ListViewContainer.cs
- EntityTemplateFactory.cs
- XmlTextWriter.cs
- TypeReference.cs
- XmlSchemaException.cs
- Helper.cs
- AuthenticateEventArgs.cs
- UserControlBuildProvider.cs
- SerializableAttribute.cs
- DisplayInformation.cs
- BufferedGraphicsManager.cs
- References.cs
- SignedXml.cs
- CodeAttributeArgument.cs
- BuildProviderAppliesToAttribute.cs
- MenuItemStyleCollection.cs
- ApplicationHost.cs
- RadioButtonAutomationPeer.cs
- SqlClientWrapperSmiStreamChars.cs
- TableParagraph.cs
- DBCommandBuilder.cs
- Dispatcher.cs
- DrawListViewSubItemEventArgs.cs
- ArrayList.cs
- MessageQueueTransaction.cs
- VisualTarget.cs
- CodeMemberMethod.cs
- Message.cs
- StatusBarItem.cs
- TogglePattern.cs
- XPathNavigatorReader.cs
- PolyLineSegment.cs
- X509Chain.cs
- System.Data.OracleClient_BID.cs
- Viewport3DAutomationPeer.cs
- PassportAuthenticationEventArgs.cs
- ApplicationHost.cs
- SchemaTableColumn.cs
- URI.cs
- LinqDataSourceUpdateEventArgs.cs
- GroupQuery.cs
- TrueReadOnlyCollection.cs
- DataGridViewSelectedRowCollection.cs
- PassportAuthenticationEventArgs.cs
- VoiceObjectToken.cs
- HandlerFactoryWrapper.cs
- TextSelectionProcessor.cs
- WebControlAdapter.cs
- ContentPlaceHolderDesigner.cs
- TypefaceMetricsCache.cs
- EditCommandColumn.cs
- SerialStream.cs
- DefaultShape.cs
- CommandDesigner.cs
- ConfigurationCollectionAttribute.cs
- MarkupWriter.cs
- EditorZone.cs
- SqlWebEventProvider.cs
- SafeEventHandle.cs
- dataprotectionpermission.cs
- Double.cs
- DataGrid.cs
- TrackBarDesigner.cs
- ComponentGlyph.cs
- StylusTip.cs
- RawStylusSystemGestureInputReport.cs
- NonParentingControl.cs
- ApplicationBuildProvider.cs
- RouteTable.cs
- DataControlFieldHeaderCell.cs
- ServiceReference.cs
- RuntimeWrappedException.cs
- MetafileHeaderEmf.cs
- BuildManager.cs
- BufferModeSettings.cs
- BrowserCapabilitiesFactory.cs