Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / 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
- RequiredFieldValidator.cs
- GeneralTransformGroup.cs
- ExtentJoinTreeNode.cs
- GenerateScriptTypeAttribute.cs
- ExpressionBindingCollection.cs
- CalloutQueueItem.cs
- X509Utils.cs
- ListenerPerfCounters.cs
- GenerateTemporaryTargetAssembly.cs
- ServiceModelConfigurationElementCollection.cs
- MetadataArtifactLoaderXmlReaderWrapper.cs
- XhtmlBasicControlAdapter.cs
- RowToParametersTransformer.cs
- WindowsFormsHelpers.cs
- ArraySubsetEnumerator.cs
- ParameterToken.cs
- AuthenticationServiceManager.cs
- Button.cs
- InkPresenter.cs
- LogFlushAsyncResult.cs
- DataGridViewRowContextMenuStripNeededEventArgs.cs
- connectionpool.cs
- PageBreakRecord.cs
- RegexRunnerFactory.cs
- ObjectDataProvider.cs
- Number.cs
- SamlAuthenticationClaimResource.cs
- CacheMemory.cs
- XmlSchemaComplexContentRestriction.cs
- KeyValueSerializer.cs
- IPAddressCollection.cs
- TableItemPatternIdentifiers.cs
- RegexCompilationInfo.cs
- HttpCapabilitiesBase.cs
- WebPartPersonalization.cs
- IProducerConsumerCollection.cs
- Baml2006KnownTypes.cs
- SEHException.cs
- User.cs
- PersonalizationProviderCollection.cs
- HttpListenerResponse.cs
- GCHandleCookieTable.cs
- BitmapEffectInputData.cs
- BuildProvider.cs
- WorkflowServiceAttributes.cs
- TextTreePropertyUndoUnit.cs
- AttributeData.cs
- EnumBuilder.cs
- XmlSchemaAttributeGroup.cs
- RenderDataDrawingContext.cs
- BindingMAnagerBase.cs
- WindowsGraphicsWrapper.cs
- ConfigurationSettings.cs
- XmlWriterSettings.cs
- BroadcastEventHelper.cs
- BatchStream.cs
- ActivityPreviewDesigner.cs
- versioninfo.cs
- ContentFileHelper.cs
- RadioButtonBaseAdapter.cs
- Certificate.cs
- ValueOfAction.cs
- DataContractSerializerSection.cs
- TemplateControlParser.cs
- ConvertEvent.cs
- DesignerWidgets.cs
- SessionPageStateSection.cs
- PagedDataSource.cs
- CaseCqlBlock.cs
- VisualBrush.cs
- TreeViewItemAutomationPeer.cs
- ManagementObject.cs
- Int32KeyFrameCollection.cs
- PriorityBinding.cs
- HyperLinkField.cs
- ProcessProtocolHandler.cs
- FieldBuilder.cs
- SapiGrammar.cs
- PropertyEmitter.cs
- DataGridTableCollection.cs
- XmlObjectSerializerReadContextComplexJson.cs
- figurelength.cs
- CollectionBuilder.cs
- ExpressionList.cs
- BooleanStorage.cs
- ToolStripInSituService.cs
- WebPartDescriptionCollection.cs
- EncryptedData.cs
- LOSFormatter.cs
- webclient.cs
- AnnotationHelper.cs
- ModelMemberCollection.cs
- SystemTcpStatistics.cs
- PermissionToken.cs
- RotateTransform.cs
- XmlValueConverter.cs
- ShapingWorkspace.cs
- formatter.cs
- Trigger.cs
- Image.cs