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
- InputReport.cs
- SectionXmlInfo.cs
- Atom10FeedFormatter.cs
- ProcessStartInfo.cs
- PrinterSettings.cs
- AssemblyNameProxy.cs
- QueryCacheEntry.cs
- CapabilitiesState.cs
- DataGridViewColumnCollection.cs
- SecUtil.cs
- BufferAllocator.cs
- SelectionItemPattern.cs
- EasingQuaternionKeyFrame.cs
- UIElement3D.cs
- ParseHttpDate.cs
- oledbmetadatacolumnnames.cs
- DbBuffer.cs
- IListConverters.cs
- UICuesEvent.cs
- TokenFactoryCredential.cs
- Clause.cs
- PrintDialog.cs
- XmlEntityReference.cs
- SqlMethodCallConverter.cs
- ObjectDataSourceMethodEventArgs.cs
- ServiceNameElementCollection.cs
- NCryptNative.cs
- HtmlInputCheckBox.cs
- ToolStripDesignerAvailabilityAttribute.cs
- GridViewRowEventArgs.cs
- XamlStream.cs
- StateBag.cs
- ObjectTag.cs
- ProtocolsSection.cs
- Geometry3D.cs
- GacUtil.cs
- DBAsyncResult.cs
- Gdiplus.cs
- NamespaceList.cs
- TimeSpanSecondsConverter.cs
- SendActivityEventArgs.cs
- CqlParserHelpers.cs
- InvalidEnumArgumentException.cs
- DataGridItem.cs
- ProfileService.cs
- TdsParameterSetter.cs
- XmlAtomicValue.cs
- HandledMouseEvent.cs
- PatternMatcher.cs
- WebHttpEndpoint.cs
- DrawingVisual.cs
- LogicalTreeHelper.cs
- WebPartExportVerb.cs
- BCLDebug.cs
- InplaceBitmapMetadataWriter.cs
- ReadOnlyDictionary.cs
- SiteMapSection.cs
- IncrementalCompileAnalyzer.cs
- AutomationFocusChangedEventArgs.cs
- OleDbSchemaGuid.cs
- MenuStrip.cs
- EntityDescriptor.cs
- SecurityElement.cs
- DSASignatureFormatter.cs
- EditorAttribute.cs
- LinkedResource.cs
- CommandDesigner.cs
- Model3D.cs
- ProcessInfo.cs
- IPAddressCollection.cs
- PageCodeDomTreeGenerator.cs
- UnsafeNativeMethodsCLR.cs
- ThreadAttributes.cs
- TagPrefixInfo.cs
- RadioButton.cs
- CreationContext.cs
- HttpClientCertificate.cs
- COSERVERINFO.cs
- _ReceiveMessageOverlappedAsyncResult.cs
- CodePageUtils.cs
- MemberListBinding.cs
- RowBinding.cs
- PeerHopCountAttribute.cs
- RuleConditionDialog.cs
- Invariant.cs
- RecipientInfo.cs
- DataControlFieldHeaderCell.cs
- StrongName.cs
- BlobPersonalizationState.cs
- ViewRendering.cs
- MessageQueueAccessControlEntry.cs
- WindowsSysHeader.cs
- ListDictionaryInternal.cs
- TreeView.cs
- ItemType.cs
- SerializationObjectManager.cs
- ConstructorExpr.cs
- ServiceContractListItem.cs
- DetailsViewRowCollection.cs
- ContentElement.cs