Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Shared / MS / Internal / FloatUtil.cs / 1305600 / 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 : [....] - Created this header // 05/20/2003 : [....] - 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 : [....] - Created this header // 05/20/2003 : [....] - 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
- DiscoveryInnerClientAdhocCD1.cs
- GeometryConverter.cs
- SocketAddress.cs
- ProcessHost.cs
- WebPartCatalogCloseVerb.cs
- ToolStripDesigner.cs
- CurrencyManager.cs
- RelativeSource.cs
- OracleRowUpdatedEventArgs.cs
- DictionarySectionHandler.cs
- EncryptedPackageFilter.cs
- ActivityTypeCodeDomSerializer.cs
- MessageBodyDescription.cs
- CodeTypeMember.cs
- Bidi.cs
- Bits.cs
- CodePageEncoding.cs
- TimeManager.cs
- DbXmlEnabledProviderManifest.cs
- ConnectionOrientedTransportManager.cs
- StructuredTypeInfo.cs
- Unit.cs
- DataGridViewCellContextMenuStripNeededEventArgs.cs
- sqlstateclientmanager.cs
- SoapTypeAttribute.cs
- ComponentChangedEvent.cs
- SqlAliasesReferenced.cs
- InternalConfigHost.cs
- FullTextBreakpoint.cs
- Decimal.cs
- AvtEvent.cs
- DataFieldCollectionEditor.cs
- StrokeDescriptor.cs
- TextAnchor.cs
- OutputCacheSettings.cs
- TextTrailingWordEllipsis.cs
- SafeCryptoHandles.cs
- XmlValueConverter.cs
- DesignerDeviceConfig.cs
- GeneratedCodeAttribute.cs
- lengthconverter.cs
- DigestComparer.cs
- SecurityPolicySection.cs
- CodeGeneratorOptions.cs
- DataBindingCollection.cs
- RootDesignerSerializerAttribute.cs
- OleDbTransaction.cs
- SerializationFieldInfo.cs
- ServiceHostFactory.cs
- DataSourceXmlTextReader.cs
- SortQuery.cs
- EventLog.cs
- InternalControlCollection.cs
- Inflater.cs
- LinkedResource.cs
- StrongNameKeyPair.cs
- NativeCppClassAttribute.cs
- RealizationDrawingContextWalker.cs
- ExtensionDataReader.cs
- DbgCompiler.cs
- CellTreeSimplifier.cs
- ConditionalDesigner.cs
- EmptyArray.cs
- TextDecoration.cs
- ProxyElement.cs
- ServiceObjectContainer.cs
- MetricEntry.cs
- EditorPart.cs
- ColumnMapProcessor.cs
- ShortcutKeysEditor.cs
- FastPropertyAccessor.cs
- TableItemPatternIdentifiers.cs
- FixedDocumentPaginator.cs
- ValidationHelpers.cs
- LinqDataSourceDisposeEventArgs.cs
- DockProviderWrapper.cs
- SmtpMail.cs
- PermissionAttributes.cs
- Visual3DCollection.cs
- ServiceHostingEnvironment.cs
- RichTextBoxConstants.cs
- TextBox.cs
- SHA256Managed.cs
- DSASignatureFormatter.cs
- ConfigUtil.cs
- WebConfigurationFileMap.cs
- ExecutionScope.cs
- SecureStringHasher.cs
- OrderedDictionary.cs
- RuntimeWrappedException.cs
- EnumUnknown.cs
- FlagPanel.cs
- DataGridViewRowContextMenuStripNeededEventArgs.cs
- HtmlMeta.cs
- ScrollBarRenderer.cs
- SQLByteStorage.cs
- CompensationParticipant.cs
- TextEffect.cs
- AuthenticationManager.cs
- WindowsFormsLinkLabel.cs