Code:
/ 4.0 / 4.0 / untmp / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / Core / System / Linq / Parallel / QueryOperators / Inlined / NullableDoubleSumAggregationOperator.cs / 1305376 / NullableDoubleSumAggregationOperator.cs
// ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== // =+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+ // // NullableDoubleSumAggregationOperator.cs // //[....] // // =-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=- using System.Collections.Generic; using System.Diagnostics.Contracts; using System.Threading; namespace System.Linq.Parallel { ////// An inlined sum aggregation and its enumerator, for nullable doubles. /// internal sealed class NullableDoubleSumAggregationOperator : InlinedAggregationOperator{ //---------------------------------------------------------------------------------------- // Constructs a new instance of a sum associative operator. // internal NullableDoubleSumAggregationOperator(IEnumerable child) : base(child) { } //--------------------------------------------------------------------------------------- // Executes the entire query tree, and aggregates the intermediate results into the // final result based on the binary operators and final reduction. // // Return Value: // The single result of aggregation. // protected override double? InternalAggregate(ref Exception singularExceptionToThrow) { // Because the final reduction is typically much cheaper than the intermediate // reductions over the individual partitions, and because each parallel partition // will do a lot of work to produce a single output element, we prefer to turn off // pipelining, and process the final reductions serially. using (IEnumerator enumerator = GetEnumerator(ParallelMergeOptions.FullyBuffered, true)) { // We just reduce the elements in each output partition. double sum = 0.0; while (enumerator.MoveNext()) { sum += enumerator.Current.GetValueOrDefault(); } return sum; } } //--------------------------------------------------------------------------------------- // Creates an enumerator that is used internally for the final aggregation step. // protected override QueryOperatorEnumerator CreateEnumerator ( int index, int count, QueryOperatorEnumerator source, object sharedData, CancellationToken cancellationToken) { return new NullableDoubleSumAggregationOperatorEnumerator (source, index, cancellationToken); } //--------------------------------------------------------------------------------------- // This enumerator type encapsulates the intermediary aggregation over the underlying // (possibly partitioned) data source. // private class NullableDoubleSumAggregationOperatorEnumerator : InlinedAggregationOperatorEnumerator { private readonly QueryOperatorEnumerator m_source; // The source data. //---------------------------------------------------------------------------------------- // Instantiates a new aggregation operator. // internal NullableDoubleSumAggregationOperatorEnumerator(QueryOperatorEnumerator source, int partitionIndex, CancellationToken cancellationToken) : base(partitionIndex, cancellationToken) { Contract.Assert(source != null); m_source = source; } //--------------------------------------------------------------------------------------- // Tallies up the sum of the underlying data source, walking the entire thing the first // time MoveNext is called on this object. // protected override bool MoveNextCore(ref double? currentElement) { double? element = default(double?); TKey keyUnused = default(TKey); QueryOperatorEnumerator source = m_source; if (source.MoveNext(ref element, ref keyUnused)) { // We just scroll through the enumerator and accumulate the sum. double tempSum = 0.0; int i = 0; do { if ((i++ & CancellationState.POLL_INTERVAL) == 0) CancellationState.ThrowIfCanceled(m_cancellationToken); tempSum += element.GetValueOrDefault(); } while (source.MoveNext(ref element, ref keyUnused)); // The sum has been calculated. Now just return. currentElement = new double?(tempSum); return true; } return false; } //---------------------------------------------------------------------------------------- // Dispose of resources associated with the underlying enumerator. // protected override void Dispose(bool disposing) { Contract.Assert(m_source != null); m_source.Dispose(); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- OdbcConnectionString.cs
- AnnotationStore.cs
- CodeGeneratorOptions.cs
- XmlDocumentType.cs
- CacheOutputQuery.cs
- SQLByteStorage.cs
- ReadOnlyHierarchicalDataSourceView.cs
- DupHandleConnectionReader.cs
- TemplateComponentConnector.cs
- LayoutEngine.cs
- StringFormat.cs
- EndpointInfo.cs
- ProxyWebPart.cs
- PieceDirectory.cs
- ThreadPool.cs
- IntegerFacetDescriptionElement.cs
- RegistrySecurity.cs
- TextProviderWrapper.cs
- Memoizer.cs
- HasCopySemanticsAttribute.cs
- dataprotectionpermissionattribute.cs
- TrustLevel.cs
- ListenerConstants.cs
- CompletedAsyncResult.cs
- LinearKeyFrames.cs
- HtmlLink.cs
- UntypedNullExpression.cs
- ActivityMetadata.cs
- InputManager.cs
- LinearKeyFrames.cs
- DataServices.cs
- DataSourceConverter.cs
- XmlSchemaSimpleTypeList.cs
- AttachmentService.cs
- AsyncOperationLifetimeManager.cs
- AlphabeticalEnumConverter.cs
- ListBase.cs
- ClientBuildManagerCallback.cs
- ResourcesBuildProvider.cs
- Registry.cs
- InfoCardArgumentException.cs
- StaticSiteMapProvider.cs
- AccessibilityHelperForXpWin2k3.cs
- Input.cs
- PropertyOverridesDialog.cs
- JournalEntryStack.cs
- ProfileSection.cs
- RegexWorker.cs
- ColorAnimation.cs
- WindowsPen.cs
- Queue.cs
- ImmutableAssemblyCacheEntry.cs
- RuntimeHandles.cs
- WebExceptionStatus.cs
- DataTablePropertyDescriptor.cs
- HorizontalAlignConverter.cs
- GeneralTransform.cs
- SupportingTokenChannel.cs
- ImageFormatConverter.cs
- DispatcherExceptionEventArgs.cs
- MultiTargetingUtil.cs
- MemberPath.cs
- TreeChangeInfo.cs
- TransactedBatchContext.cs
- SqlMethodAttribute.cs
- BaseCodeDomTreeGenerator.cs
- GeneratedView.cs
- AutomationEvent.cs
- OpacityConverter.cs
- Set.cs
- _StreamFramer.cs
- DataGridViewRowsAddedEventArgs.cs
- NavigationProgressEventArgs.cs
- NameObjectCollectionBase.cs
- EmptyStringExpandableObjectConverter.cs
- Propagator.cs
- XmlDownloadManager.cs
- BrowserTree.cs
- QueueProcessor.cs
- TagPrefixCollection.cs
- EditorPartChrome.cs
- PrintPageEvent.cs
- FixedFindEngine.cs
- SqlWriter.cs
- DiscoveryClientDocuments.cs
- CacheEntry.cs
- TypeCollectionPropertyEditor.cs
- SQLSingleStorage.cs
- AudioLevelUpdatedEventArgs.cs
- AssemblyAttributesGoHere.cs
- CompilerGeneratedAttribute.cs
- EnvelopedPkcs7.cs
- nulltextnavigator.cs
- EventlogProvider.cs
- ImplicitInputBrush.cs
- SystemIPInterfaceProperties.cs
- RSAPKCS1KeyExchangeFormatter.cs
- LogicalExpr.cs
- ImmutablePropertyDescriptorGridEntry.cs
- DataGridViewControlCollection.cs