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
- XPathSingletonIterator.cs
- XmlSerializationReader.cs
- DataTable.cs
- SecurityTokenTypes.cs
- SafeHandles.cs
- BindingGroup.cs
- ThumbButtonInfoCollection.cs
- NonSerializedAttribute.cs
- RemoteWebConfigurationHost.cs
- DispatcherHooks.cs
- PropertiesTab.cs
- SiteMapSection.cs
- DataSysAttribute.cs
- Image.cs
- RijndaelManaged.cs
- MailWebEventProvider.cs
- GlyphRunDrawing.cs
- BaseTreeIterator.cs
- AccessorTable.cs
- CompilerGeneratedAttribute.cs
- SrgsSemanticInterpretationTag.cs
- TreeChangeInfo.cs
- CopyCodeAction.cs
- TextFormatterImp.cs
- DataGridViewImageCell.cs
- AsyncWaitHandle.cs
- NavigationProgressEventArgs.cs
- ReadOnlyHierarchicalDataSource.cs
- CacheAxisQuery.cs
- input.cs
- WebBrowser.cs
- DoubleAverageAggregationOperator.cs
- DnsPermission.cs
- WindowsSpinner.cs
- URLAttribute.cs
- SafeRightsManagementPubHandle.cs
- Point3DAnimationBase.cs
- COM2PropertyPageUITypeConverter.cs
- OrthographicCamera.cs
- documentsequencetextcontainer.cs
- SqlCrossApplyToCrossJoin.cs
- comcontractssection.cs
- EventProperty.cs
- Action.cs
- ObjectCloneHelper.cs
- Transform3DCollection.cs
- TriggerBase.cs
- FixedSOMTableCell.cs
- SqlConnectionFactory.cs
- SuspendDesigner.cs
- BlobPersonalizationState.cs
- FunctionGenerator.cs
- XamlReader.cs
- BasicCellRelation.cs
- LineBreak.cs
- ControllableStoryboardAction.cs
- PathFigureCollection.cs
- HwndHostAutomationPeer.cs
- CalculatedColumn.cs
- PresentationTraceSources.cs
- DetailsViewRow.cs
- ActiveXSite.cs
- ISAPIApplicationHost.cs
- DesignRelation.cs
- Decorator.cs
- DataGridBoolColumn.cs
- KeyProperty.cs
- SqlSelectStatement.cs
- TypedTableBase.cs
- Separator.cs
- SoapHeaderAttribute.cs
- CmsUtils.cs
- XmlSchemaInfo.cs
- InvalidDocumentContentsException.cs
- HwndTarget.cs
- VariableAction.cs
- FormatControl.cs
- DescriptionAttribute.cs
- DataRecordInternal.cs
- TogglePatternIdentifiers.cs
- FlowDocumentPaginator.cs
- GroupItem.cs
- CodeVariableReferenceExpression.cs
- PenLineCapValidation.cs
- ContractNamespaceAttribute.cs
- __ConsoleStream.cs
- Queue.cs
- Listbox.cs
- DBConnection.cs
- WebControlAdapter.cs
- InputMethod.cs
- SessionPageStateSection.cs
- WorkflowDebuggerSteppingAttribute.cs
- WpfGeneratedKnownTypes.cs
- TemplatePartAttribute.cs
- CuspData.cs
- ComponentResourceKey.cs
- ObjectHandle.cs
- DocumentPageView.cs
- WindowAutomationPeer.cs