scala.collection.parallel.immutable

ParIterable

trait ParIterable [+T] extends Iterable[T] with ParIterable[T] with GenericParTemplate[T, ParIterable] with ParIterableLike[T, ParIterable[T], Iterable[T]]

A template trait for immutable parallel iterable collections.

This is a base trait for Scala parallel collections. It defines behaviour common to all parallel collections. Concrete parallel collections should inherit this trait and ParIterable if they want to define specific combiner factories.

Parallel operations are implemented with divide and conquer style algorithms that parallelize well. The basic idea is to split the collection into smaller parts until they are small enough to be operated on sequentially.

All of the parallel operations are implemented as tasks within this trait. Tasks rely on the concept of splitters, which extend iterators. Every parallel collection defines:

    def parallelIterator: ParIterableIterator[T]

which returns an instance of ParIterableIterator[T], which is a subtype of Splitter[T]. Parallel iterators have a method remaining to check the remaining number of elements, and method split which is defined by splitters. Method split divides the splitters iterate over into disjunct subsets:

    def split: Seq[Splitter]

which splits the splitter into a sequence of disjunct subsplitters. This is typically a very fast operation which simply creates wrappers around the receiver collection. This can be repeated recursively.

Method newCombiner produces a new combiner. Combiners are an extension of builders. They provide a method combine which combines two combiners and returns a combiner containing elements of both combiners. This method can be implemented by aggressively copying all the elements into the new combiner or by lazily binding their results. It is recommended to avoid copying all of the elements for performance reasons, although that cost might be negligible depending on the use case. Standard parallel collection combiners avoid copying when merging results, relying either on a two-step lazy construction or specific data-structure properties.

Methods:

    def seq: Sequential
    def par: Repr

produce the sequential or parallel implementation of the collection, respectively. Method par just returns a reference to this parallel collection. Method seq is efficient - it will not copy the elements. Instead, it will create a sequential version of the collection using the same underlying data structure. Note that this is not the case for sequential collections in general - they may copy the elements and produce a different underlying data structure.

The combination of methods toMap, toSeq or toSet along with par and seq is a flexible way to change between different collection types.

The method:

    def threshold(sz: Int, p: Int): Int

provides an estimate on the minimum number of elements the collection has before the splitting stops and depends on the number of elements in the collection. A rule of the thumb is the number of elements divided by 8 times the parallelism level. This method may be overridden in concrete implementations if necessary.

Since this trait extends the Iterable trait, methods like size must also be implemented in concrete collections, while iterator forwards to parallelIterator by default.

Each parallel collection is bound to a specific fork/join pool, on which dormant worker threads are kept. The fork/join pool contains other information such as the parallelism level, that is, the number of processors used. When a collection is created, it is assigned the default fork/join pool found in the scala.parallel package object.

Parallel collections are not necessarily ordered in terms of the foreach operation (see Traversable). Parallel sequences have a well defined order for iterators - creating an iterator and traversing the elements linearly will always yield the same order. However, bulk operations such as foreach, map or filter always occur in undefined orders for all parallel collections.

Existing parallel collection implementations provide strict parallel iterators. Strict parallel iterators are aware of the number of elements they have yet to traverse. It's also possible to provide non-strict parallel iterators, which do not know the number of elements remaining. To do this, the new collection implementation must override isStrictSplitterCollection to false. This will make some operations unavailable.

To create a new parallel collection, extend the ParIterable trait, and implement size, parallelIterator, newCombiner and seq. Having an implicit combiner factory requires extending this trait in addition, as well as providing a companion object, as with regular collections.

Method size is implemented as a constant time operation for parallel collections, and parallel collection operations rely on this assumption.

A template trait for immutable parallel iterable collections.

This is a base trait for Scala parallel collections. It defines behaviour common to all parallel collections. Concrete parallel collections should inherit this trait and ParIterable if they want to define specific combiner factories.

Parallel operations are implemented with divide and conquer style algorithms that parallelize well. The basic idea is to split the collection into smaller parts until they are small enough to be operated on sequentially.

All of the parallel operations are implemented as tasks within this trait. Tasks rely on the concept of splitters, which extend iterators. Every parallel collection defines:

    def parallelIterator: ParIterableIterator[T]

which returns an instance of ParIterableIterator[T], which is a subtype of Splitter[T]. Parallel iterators have a method remaining to check the remaining number of elements, and method split which is defined by splitters. Method split divides the splitters iterate over into disjunct subsets:

    def split: Seq[Splitter]

which splits the splitter into a sequence of disjunct subsplitters. This is typically a very fast operation which simply creates wrappers around the receiver collection. This can be repeated recursively.

Method newCombiner produces a new combiner. Combiners are an extension of builders. They provide a method combine which combines two combiners and returns a combiner containing elements of both combiners. This method can be implemented by aggressively copying all the elements into the new combiner or by lazily binding their results. It is recommended to avoid copying all of the elements for performance reasons, although that cost might be negligible depending on the use case. Standard parallel collection combiners avoid copying when merging results, relying either on a two-step lazy construction or specific data-structure properties.

Methods:

    def seq: Sequential
    def par: Repr

produce the sequential or parallel implementation of the collection, respectively. Method par just returns a reference to this parallel collection. Method seq is efficient - it will not copy the elements. Instead, it will create a sequential version of the collection using the same underlying data structure. Note that this is not the case for sequential collections in general - they may copy the elements and produce a different underlying data structure.

The combination of methods toMap, toSeq or toSet along with par and seq is a flexible way to change between different collection types.

The method:

    def threshold(sz: Int, p: Int): Int

provides an estimate on the minimum number of elements the collection has before the splitting stops and depends on the number of elements in the collection. A rule of the thumb is the number of elements divided by 8 times the parallelism level. This method may be overridden in concrete implementations if necessary.

Since this trait extends the Iterable trait, methods like size must also be implemented in concrete collections, while iterator forwards to parallelIterator by default.

Each parallel collection is bound to a specific fork/join pool, on which dormant worker threads are kept. The fork/join pool contains other information such as the parallelism level, that is, the number of processors used. When a collection is created, it is assigned the default fork/join pool found in the scala.parallel package object.

Parallel collections are not necessarily ordered in terms of the foreach operation (see Traversable). Parallel sequences have a well defined order for iterators - creating an iterator and traversing the elements linearly will always yield the same order. However, bulk operations such as foreach, map or filter always occur in undefined orders for all parallel collections.

Existing parallel collection implementations provide strict parallel iterators. Strict parallel iterators are aware of the number of elements they have yet to traverse. It's also possible to provide non-strict parallel iterators, which do not know the number of elements remaining. To do this, the new collection implementation must override isStrictSplitterCollection to false. This will make some operations unavailable.

To create a new parallel collection, extend the ParIterable trait, and implement size, parallelIterator, newCombiner and seq. Having an implicit combiner factory requires extending this trait in addition, as well as providing a companion object, as with regular collections.

Method size is implemented as a constant time operation for parallel collections, and parallel collection operations rely on this assumption.

T

the element type of the collection

go to: companion
linear super types: ParIterable[T], ParIterableLike[T, ParIterable[T], Iterable[T]], Parallel, CustomParallelizable[T, ParIterable[T]], GenericParTemplate[T, ParIterable], HasNewCombiner[T, ParIterable[T]], Iterable[T], Iterable[T], IterableLike[T, ParIterable[T]], Equals, Traversable[T], Immutable, Traversable[T], GenericTraversableTemplate[T, ParIterable], TraversableLike[T, ParIterable[T]], Parallelizable[T, ParIterable[T]], TraversableOnce[T], FilterMonadic[T, ParIterable[T]], HasNewBuilder[T, ParIterable[T]], AnyRef, Any
known subclasses: ParVector, ParMap, ParSet, ParHashMap, ParRange, ParHashSet, ParSeq
source: ParIterable.scala
    since
  1. 2.9

Ordering
  1. Alphabetic
  2. By inheritance
Inherited
  1. Hide All
  2. Show all
  1. ParIterable
  2. ParIterable
  3. ParIterableLike
  4. Parallel
  5. CustomParallelizable
  6. GenericParTemplate
  7. HasNewCombiner
  8. Iterable
  9. Iterable
  10. IterableLike
  11. Equals
  12. Traversable
  13. Immutable
  14. Traversable
  15. GenericTraversableTemplate
  16. TraversableLike
  17. Parallelizable
  18. TraversableOnce
  19. FilterMonadic
  20. HasNewBuilder
  21. AnyRef
  22. Any
Visibility
  1. Public
  2. All
Impl.
  1. Concrete
  2. Abstract

Type Members

  1. trait Accessor [R, Tp] extends StrictSplitterCheckTask[R, Tp]

    Standard accessor task that iterates over the elements of the collection.

  2. class Aggregate [S] extends Accessor[S, Aggregate[S]]

    attributes: protected[this]
  3. trait BuilderOps [Elem, To] extends AnyRef

  4. class Collect [S, That] extends Transformer[Combiner[S, That], Collect[S, That]]

    attributes: protected[this]
  5. class Composite [FR, SR, R, First <: ParIterableLike.this.StrictSplitterCheckTask[FR, _], Second <: ParIterableLike.this.StrictSplitterCheckTask[SR, _]] extends NonDivisibleTask[R, Composite[FR, SR, R, First, Second]]

    attributes: protected[this] abstract
  6. class Copy [U >: T, That] extends Transformer[Combiner[U, That], Copy[U, That]]

    attributes: protected
  7. class CopyToArray [U >: T, This >: Repr] extends Accessor[Unit, CopyToArray[U, This]]

    attributes: protected[this]
  8. class Count extends Accessor[Int, Count]

    attributes: protected[this]
  9. class CreateScanTree [U >: T] extends Transformer[ScanTree[U], CreateScanTree[U]]

    attributes: protected[this]
  10. class Drop [U >: T, This >: Repr] extends Transformer[Combiner[U, This], Drop[U, This]]

    attributes: protected[this]
  11. class Exists extends Accessor[Boolean, Exists]

    attributes: protected[this]
  12. class Filter [U >: T, This >: Repr] extends Transformer[Combiner[U, This], Filter[U, This]]

    attributes: protected[this]
  13. class FilterNot [U >: T, This >: Repr] extends Transformer[Combiner[U, This], FilterNot[U, This]]

    attributes: protected[this]
  14. class Find [U >: T] extends Accessor[Option[U], Find[U]]

    attributes: protected[this]
  15. class FlatMap [S, That] extends Transformer[Combiner[S, That], FlatMap[S, That]]

    attributes: protected[this]
  16. class Fold [U >: T] extends Accessor[U, Fold[U]]

    attributes: protected[this]
  17. class Forall extends Accessor[Boolean, Forall]

    attributes: protected[this]
  18. class Foreach [S] extends Accessor[Unit, Foreach[S]]

    attributes: protected[this]
  19. class FromScanTree [U >: T, That] extends StrictSplitterCheckTask[Combiner[U, That], FromScanTree[U, That]]

    attributes: protected[this]
  20. class GroupBy [K, U >: T] extends Transformer[HashMapCombiner[K, U], GroupBy[K, U]]

    attributes: protected[this]
  21. class Map [S, That] extends Transformer[Combiner[S, That], Map[S, That]]

    attributes: protected[this]
  22. class Max [U >: T] extends Accessor[Option[U], Max[U]]

    attributes: protected[this]
  23. class Min [U >: T] extends Accessor[Option[U], Min[U]]

    attributes: protected[this]
  24. trait NonDivisible [R] extends NonDivisibleTask[R, NonDivisible[R]]

    attributes: protected[this]
  25. trait NonDivisibleTask [R, Tp] extends StrictSplitterCheckTask[R, Tp]

    attributes: protected[this]
  26. class ParComposite [FR, SR, R, First <: ParIterableLike.this.StrictSplitterCheckTask[FR, _], Second <: ParIterableLike.this.StrictSplitterCheckTask[SR, _]] extends Composite[FR, SR, R, First, Second]

    Performs two tasks in parallel, and waits for both to finish.

  27. trait ParIterator extends ParIterableIterator[T]

    Parallel iterators are split iterators that have additional accessor and transformer methods defined in terms of methods next and hasNext.

  28. class Partition [U >: T, This >: Repr] extends Transformer[(Combiner[U, This], Combiner[U, This]), Partition[U, This]]

    attributes: protected[this]
  29. class Product [U >: T] extends Accessor[U, Product[U]]

    attributes: protected[this]
  30. class Reduce [U >: T] extends Accessor[Option[U], Reduce[U]]

    attributes: protected[this]
  31. class ResultMapping [R, Tp, R1] extends NonDivisibleTask[R1, ResultMapping[R, Tp, R1]]

    attributes: protected[this] abstract
  32. type SSCTask [R, Tp] = StrictSplitterCheckTask[R, Tp]

    definition classes: ParIterableLike
  33. case class ScanLeaf [U >: T] ( pit : ParIterableIterator[U] , op : (U, U) ⇒ U , from : Int , len : Int , prev : Option[ScanLeaf[U]] , acc : U ) extends ScanTree[U] with Product with Serializable

    attributes: protected[this]
  34. case class ScanNode [U >: T] ( left : ScanTree[U] , right : ScanTree[U] ) extends ScanTree[U] with Product with Serializable

    attributes: protected[this]
  35. trait ScanTree [U >: T] extends AnyRef

    attributes: protected[this]
  36. type Self = ParIterable[T]

    The type implementing this traversable

    The type implementing this traversable

    attributes: protected
    definition classes: TraversableLike
  37. class SeqComposite [FR, SR, R, First <: ParIterableLike.this.StrictSplitterCheckTask[FR, _], Second <: ParIterableLike.this.StrictSplitterCheckTask[SR, _]] extends Composite[FR, SR, R, First, Second]

    Sequentially performs one task after another.

  38. trait SignalContextPassingIterator [+IterRepr <: ParIterator] extends ParIterator

    A stackable modification that ensures signal contexts get passed along the iterators.

  39. trait SignallingOps [PI <: DelegatedSignalling] extends AnyRef

  40. class Slice [U >: T, This >: Repr] extends Transformer[Combiner[U, This], Slice[U, This]]

    attributes: protected[this]
  41. class Span [U >: T, This >: Repr] extends Transformer[(Combiner[U, This], Combiner[U, This]), Span[U, This]]

    attributes: protected[this]
  42. class SplitAt [U >: T, This >: Repr] extends Transformer[(Combiner[U, This], Combiner[U, This]), SplitAt[U, This]]

    attributes: protected[this]
  43. trait StrictSplitterCheckTask [R, Tp] extends Task[R, Tp]

    attributes: protected
  44. class Sum [U >: T] extends Accessor[U, Sum[U]]

    attributes: protected[this]
  45. class Take [U >: T, This >: Repr] extends Transformer[Combiner[U, This], Take[U, This]]

    attributes: protected[this]
  46. class TakeWhile [U >: T, This >: Repr] extends Transformer[(Combiner[U, This], Boolean), TakeWhile[U, This]]

    attributes: protected[this]
  47. trait TaskOps [R, Tp] extends AnyRef

  48. class ToParCollection [U >: T, That] extends Transformer[Combiner[U, That], ToParCollection[U, That]]

    attributes: protected[this]
  49. class ToParMap [K, V, That] extends Transformer[Combiner[(K, V), That], ToParMap[K, V, That]]

    attributes: protected[this]
  50. trait Transformer [R, Tp] extends Accessor[R, Tp]

    attributes: protected
  51. class WithFilter extends FilterMonadic[A, Repr]

    A class supporting filtered operations.

  52. class Zip [U >: T, S, That] extends Transformer[Combiner[(U, S), That], Zip[U, S, That]]

    attributes: protected[this]
  53. class ZipAll [U >: T, S, That] extends Transformer[Combiner[(U, S), That], ZipAll[U, S, That]]

    attributes: protected[this]

Value Members

  1. def != ( arg0 : AnyRef ) : Boolean

    attributes: final
    definition classes: AnyRef
  2. def != ( arg0 : Any ) : Boolean

    o != arg0 is the same as !(o == (arg0)).

    o != arg0 is the same as !(o == (arg0)).

    arg0

    the object to compare against this object for dis-equality.

    returns

    false if the receiver object is equivalent to the argument; true otherwise.

    attributes: final
    definition classes: Any
  3. def ## () : Int

    attributes: final
    definition classes: AnyRef → Any
  4. def $asInstanceOf [T0] () : T0

    attributes: final
    definition classes: AnyRef
  5. def $isInstanceOf [T0] () : Boolean

    attributes: final
    definition classes: AnyRef
  6. def ++ [B] ( that : TraversableOnce[B] ) : ParIterable[B]

    [use case] Concatenates this parallel iterable with the elements of a traversable collection.

    [use case]

    Concatenates this parallel iterable with the elements of a traversable collection.

    B

    the element type of the returned collection.

    that

    the traversable to append.

    returns

    a new parallel iterable which contains all elements of this parallel iterable followed by all elements of that.

    attributes: abstract
    definition classes: TraversableLike
  7. def ++ [U >: T, That] ( that : TraversableOnce[U] )(implicit bf : CanBuildFrom[ParIterable[T], U, That] ) : That

    Concatenates this parallel iterable with the elements of a traversable collection.

    Concatenates this parallel iterable with the elements of a traversable collection.

    That

    the class of the returned collection. Where possible, That is the same class as the current collection class Repr, but this depends on the element type B being admissible for that class, which means that an implicit instance of type CanBuildFrom[Repr, B, That] is found.

    that

    the traversable to append.

    bf

    an implicit value of class CanBuildFrom which determines the result class That from the current representation type Repr and and the new element type B.

    returns

    a new collection of type That which contains all elements of this parallel iterable followed by all elements of that.

    definition classes: ParIterableLikeTraversableLike
  8. def ++: [B >: T, That] ( that : Traversable[B] )(implicit bf : CanBuildFrom[ParIterable[T], B, That] ) : That

    This overload exists because: for the implementation of ++: we should reuse that of ++ because many collections override it with more efficient versions.

    This overload exists because: for the implementation of ++: we should reuse that of ++ because many collections override it with more efficient versions. Since TraversableOnce has no '++' method, we have to implement that directly, but Traversable and down can use the overload.

    definition classes: TraversableLike
  9. def ++: [B] ( that : TraversableOnce[B] ) : ParIterable[B]

    [use case] Concatenates this parallel iterable with the elements of a traversable collection.

    [use case]

    Concatenates this parallel iterable with the elements of a traversable collection. It differs from ++ in that the right operand determines the type of the resulting collection rather than the left one.

    B

    the element type of the returned collection.

    that

    the traversable to append.

    returns

    a new parallel iterable which contains all elements of this parallel iterable followed by all elements of that.

    attributes: abstract
    definition classes: TraversableLike
  10. def ++: [B >: T, That] ( that : TraversableOnce[B] )(implicit bf : CanBuildFrom[ParIterable[T], B, That] ) : That

    Concatenates this parallel iterable with the elements of a traversable collection.

    Concatenates this parallel iterable with the elements of a traversable collection. It differs from ++ in that the right operand determines the type of the resulting collection rather than the left one.

    B

    the element type of the returned collection.

    That

    the class of the returned collection. Where possible, That is the same class as the current collection class Repr, but this depends on the element type B being admissible for that class, which means that an implicit instance of type CanBuildFrom[Repr, B, That] is found.

    that

    the traversable to append.

    bf

    an implicit value of class CanBuildFrom which determines the result class That from the current representation type Repr and and the new element type B.

    returns

    a new collection of type That which contains all elements of this parallel iterable followed by all elements of that.

    definition classes: TraversableLike
  11. def /: [B] ( z : B )( op : (B, T) ⇒ B ) : B

    Applies a binary operator to a start value and all elements of this parallel iterable, going left to right.

    Applies a binary operator to a start value and all elements of this parallel iterable, going left to right.

    Note: /: is alternate syntax for foldLeft; z /: xs is the same as xs foldLeft z.

    Note: will not terminate for infinite-sized collections.

    Note: might return different results for different runs, unless the underlying collection type is ordered. or the operator is associative and commutative.

    B

    the result type of the binary operator.

    z

    the start value.

    op

    the binary operator.

    returns

    the result of inserting op between consecutive elements of this parallel iterable, going left to right with the start value z on the left:

                op(...op(op(z, x,,1,,), x,,2,,), ..., x,,n,,)
    

    where x,,1,,, ..., x,,n,, are the elements of this parallel iterable.

    definition classes: TraversableOnce
  12. def :\ [B] ( z : B )( op : (T, B) ⇒ B ) : B

    Applies a binary operator to all elements of this parallel iterable and a start value, going right to left.

    Applies a binary operator to all elements of this parallel iterable and a start value, going right to left.

    Note: :\ is alternate syntax for foldRight; xs :\ z is the same as xs foldRight z.

    Note: will not terminate for infinite-sized collections.

    Note: might return different results for different runs, unless the underlying collection type is ordered. or the operator is associative and commutative.

    B

    the result type of the binary operator.

    z

    the start value

    op

    the binary operator

    returns

    the result of inserting op between consecutive elements of this parallel iterable, going right to left with the start value z on the right:

                op(x,,1,,, op(x,,2,,, ... op(x,,n,,, z)...))
    

    where x,,1,,, ..., x,,n,, are the elements of this parallel iterable.

    definition classes: TraversableOnce
  13. def == ( arg0 : AnyRef ) : Boolean

    o == arg0 is the same as if (o eq null) arg0 eq null else o.equals(arg0).

    o == arg0 is the same as if (o eq null) arg0 eq null else o.equals(arg0).

    arg0

    the object to compare against this object for equality.

    returns

    true if the receiver object is equivalent to the argument; false otherwise.

    attributes: final
    definition classes: AnyRef
  14. def == ( arg0 : Any ) : Boolean

    o == arg0 is the same as o.equals(arg0).

    o == arg0 is the same as o.equals(arg0).

    arg0

    the object to compare against this object for equality.

    returns

    true if the receiver object is equivalent to the argument; false otherwise.

    attributes: final
    definition classes: Any
  15. def addString ( b : StringBuilder ) : StringBuilder

    Appends all elements of this parallel iterable to a string builder.

    Appends all elements of this parallel iterable to a string builder. The written text consists of the string representations (w.r.t. the method toString) of all elements of this parallel iterable without any separator string.

    b

    the string builder to which elements are appended.

    returns

    the string builder b to which elements were appended.

    definition classes: TraversableOnce
  16. def addString ( b : StringBuilder , sep : String ) : StringBuilder

    Appends all elements of this parallel iterable to a string builder using a separator string.

    Appends all elements of this parallel iterable to a string builder using a separator string. The written text consists of the string representations (w.r.t. the method toString) of all elements of this parallel iterable, separated by the string sep.

    b

    the string builder to which elements are appended.

    sep

    the separator string.

    returns

    the string builder b to which elements were appended.

    definition classes: TraversableOnce
  17. def addString ( b : StringBuilder , start : String , sep : String , end : String ) : StringBuilder

    Appends all elements of this parallel iterable to a string builder using start, end, and separator strings.

    Appends all elements of this parallel iterable to a string builder using start, end, and separator strings. The written text begins with the string start and ends with the string end. Inside, the string representations (w.r.t. the method toString) of all elements of this parallel iterable are separated by the string sep.

    b

    the string builder to which elements are appended.

    start

    the starting string.

    sep

    the separator string.

    end

    the ending string.

    returns

    the string builder b to which elements were appended.

    definition classes: TraversableOnce
  18. def aggregate [S] ( z : S )( seqop : (S, T) ⇒ S , combop : (S, S) ⇒ S ) : S

    Aggregates the results of applying an operator to subsequent elements.

    Aggregates the results of applying an operator to subsequent elements.

    This is a more general form of fold and reduce. It has similar semantics, but does not require the result to be a supertype of the element type. It traverses the elements in different partitions sequentially, using seqop to update the result, and then applies combop to results from different partitions. The implementation of this operation may operate on an arbitrary number of collection partitions, so combop may be invoked arbitrary number of times.

    For example, one might want to process some elements and then produce a Set. In this case, seqop would process an element and append it to the list, while combop would concatenate two lists from different partitions together. The initial value z would be an empty set.

       pc.aggregate(Set[Int]())(_ += process(_), _ ++ _)
    

    Another example is calculating geometric mean from a collection of doubles (one would typically require big doubles for this).

    S

    the type of accumulated results

    z

    the initial value for the accumulated result of the partition - this will typically be the neutral element for the seqop operator (e.g. Nil for list concatenation or 0 for summation)

    seqop

    an operator used to accumulate results within a partition

    combop

    an associative operator used to combine results from different partitions

    definition classes: ParIterableLike
  19. def asInstanceOf [T0] : T0

    This method is used to cast the receiver object to be of type T0.

    This method is used to cast the receiver object to be of type T0.

    Note that the success of a cast at runtime is modulo Scala's erasure semantics. Therefore the expression 1.asInstanceOf[String] will throw a ClassCastException at runtime, while the expression List(1).asInstanceOf[List[String]] will not. In the latter example, because the type argument is erased as part of compilation it is not possible to check whether the contents of the list are of the requested typed.

    returns

    the receiver object.

    attributes: final
    definition classes: Any
  20. implicit def builder2ops [Elem, To] ( cb : Builder[Elem, To] ) : BuilderOps[Elem, To]

    attributes: protected implicit
    definition classes: ParIterableLike
  21. def canEqual ( that : Any ) : Boolean

    Method called from equality methods, so that user-defined subclasses can refuse to be equal to other collections of the same kind.

    Method called from equality methods, so that user-defined subclasses can refuse to be equal to other collections of the same kind.

    that

    The object with which this parallel iterable should be compared

    returns

    true, if this parallel iterable can possibly equal that, false otherwise. The test takes into consideration only the run-time types of objects but ignores their elements.

    definition classes: IterableLikeEquals
  22. def cbfactory : () ⇒ Combiner[T, ParIterable[T]]

    attributes: protected[this]
    definition classes: ParIterableLike
  23. def clone () : AnyRef

    This method creates and returns a copy of the receiver object.

    This method creates and returns a copy of the receiver object.

    The default implementation of the clone method is platform dependent.

    returns

    a copy of the receiver object.

    attributes: protected[lang]
    definition classes: AnyRef
    annotations: @throws()
  24. def collect [B] ( pf : PartialFunction[T, B] ) : ParIterable[B]

    [use case] Builds a new collection by applying a partial function to all elements of this parallel iterable on which the function is defined.

    [use case]

    Builds a new collection by applying a partial function to all elements of this parallel iterable on which the function is defined.

    B

    the element type of the returned collection.

    pf

    the partial function which filters and maps the parallel iterable.

    returns

    a new parallel iterable resulting from applying the given partial function pf to each element on which it is defined and collecting the results. The order of the elements is preserved.

    attributes: abstract
    definition classes: TraversableLike
  25. def collect [S, That] ( pf : PartialFunction[T, S] )(implicit bf : CanBuildFrom[ParIterable[T], S, That] ) : That

    Builds a new collection by applying a partial function to all elements of this parallel iterable on which the function is defined.

    Builds a new collection by applying a partial function to all elements of this parallel iterable on which the function is defined.

    That

    the class of the returned collection. Where possible, That is the same class as the current collection class Repr, but this depends on the element type B being admissible for that class, which means that an implicit instance of type CanBuildFrom[Repr, B, That] is found.

    pf

    the partial function which filters and maps the parallel iterable.

    bf

    an implicit value of class CanBuildFrom which determines the result class That from the current representation type Repr and and the new element type B.

    returns

    a new collection of type That resulting from applying the partial function pf to each element on which it is defined and collecting the results. The order of the elements is preserved.

    definition classes: ParIterableLikeTraversableLike
  26. def collectFirst [B] ( pf : PartialFunction[T, B] ) : Option[B]

    Finds the first element of the parallel iterable for which the given partial function is defined, and applies the partial function to it.

    Finds the first element of the parallel iterable for which the given partial function is defined, and applies the partial function to it.

    Note: may not terminate for infinite-sized collections.

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    pf

    the partial function

    returns

    an option value containing pf applied to the first value for which it is defined, or None if none exists.

    definition classes: TraversableOnce
    Example :
    1. Seq("a", 1, 5L).collectFirst({ case x: Int => x*10 }) = Some(10)

  27. def companion : GenericCompanion[ParIterable] with GenericParCompanion[ParIterable]

    The factory companion object that builds instances of class ParIterable.

    The factory companion object that builds instances of class ParIterable. (or its Iterable superclass where class ParIterable is not a Seq.)

  28. def copyToArray ( xs : Array[T] , start : Int , len : Int ) : Unit

    [use case] Copies elements of this parallel iterable to an array.

    [use case]

    Copies elements of this parallel iterable to an array. Fills the given array xs with at most len elements of this parallel iterable, starting at position start. Copying will stop once either the end of the current parallel iterable is reached, or the end of the array is reached, or len elements have been copied.

    xs

    the array to fill.

    start

    the starting index.

    len

    the maximal number of elements to copy.

    attributes: abstract
    definition classes: TraversableLike
  29. def copyToArray [U >: T] ( xs : Array[U] , start : Int , len : Int ) : Unit

    Copies elements of this parallel iterable to an array.

    Copies elements of this parallel iterable to an array. Fills the given array xs with at most len elements of this parallel iterable, starting at position start. Copying will stop once either the end of the current parallel iterable is reached, or the end of the array is reached, or len elements have been copied.

    Note: will not terminate for infinite-sized collections.

    xs

    the array to fill.

    start

    the starting index.

    len

    the maximal number of elements to copy.

  30. def copyToArray ( xs : Array[T] ) : Unit

    [use case] Copies values of this parallel iterable to an array.

    [use case]

    Copies values of this parallel iterable to an array. Fills the given array xs with values of this parallel iterable. Copying will stop once either the end of the current parallel iterable is reached, or the end of the array is reached.

    xs

    the array to fill.

    attributes: abstract
    definition classes: TraversableOnce
  31. def copyToArray [B >: T] ( xs : Array[B] ) : Unit

    Copies values of this parallel iterable to an array.

    Copies values of this parallel iterable to an array. Fills the given array xs with values of this parallel iterable. Copying will stop once either the end of the current parallel iterable is reached, or the end of the array is reached.

    Note: will not terminate for infinite-sized collections.

    B

    the type of the elements of the array.

    xs

    the array to fill.

    definition classes: TraversableOnce
  32. def copyToArray ( xs : Array[T] , start : Int ) : Unit

    [use case] Copies values of this parallel iterable to an array.

    [use case]

    Copies values of this parallel iterable to an array. Fills the given array xs with values of this parallel iterable, after skipping start values. Copying will stop once either the end of the current parallel iterable is reached, or the end of the array is reached.

    xs

    the array to fill.

    start

    the starting index.

    attributes: abstract
    definition classes: TraversableOnce
  33. def copyToArray [B >: T] ( xs : Array[B] , start : Int ) : Unit

    Copies values of this parallel iterable to an array.

    Copies values of this parallel iterable to an array. Fills the given array xs with values of this parallel iterable, after skipping start values. Copying will stop once either the end of the current parallel iterable is reached, or the end of the array is reached.

    Note: will not terminate for infinite-sized collections.

    B

    the type of the elements of the array.

    xs

    the array to fill.

    start

    the starting index.

    definition classes: TraversableOnce
  34. def copyToBuffer [B >: T] ( dest : Buffer[B] ) : Unit

    Copies all elements of this parallel iterable to a buffer.

    Copies all elements of this parallel iterable to a buffer.

    Note: will not terminate for infinite-sized collections.

    dest

    The buffer to which elements are copied.

    definition classes: TraversableOnce
  35. def count ( p : (T) ⇒ Boolean ) : Int

    Counts the number of elements in the parallel iterable which satisfy a predicate.

    Counts the number of elements in the parallel iterable which satisfy a predicate.

    p

    the predicate used to test elements.

    returns

    the number of elements satisfying the predicate p.

    definition classes: ParIterableLikeTraversableOnce
  36. def debugBuffer : ArrayBuffer[String]

    definition classes: ParIterableLike
  37. implicit def delegatedSignalling2ops [PI <: DelegatedSignalling] ( it : PI ) : SignallingOps[PI]

    attributes: protected implicit
    definition classes: ParIterableLike
  38. def drop ( n : Int ) : ParIterable[T]

    Selects all elements except first n ones.

    Selects all elements except first n ones.

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    n

    the number of elements to drop from this parallel iterable.

    returns

    a parallel iterable consisting of all elements of this parallel iterable except the first n ones, or else the empty parallel iterable, if this parallel iterable has less than n elements.

    definition classes: ParIterableLikeTraversableLike
  39. def dropRight ( n : Int ) : ParIterable[T]

    Selects all elements except last n ones.

    Selects all elements except last n ones.

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    n

    The number of elements to take

    returns

    a parallel iterable consisting of all elements of this parallel iterable except the last n ones, or else the empty parallel iterable, if this parallel iterable has less than n elements.

    definition classes: IterableLike
  40. def dropWhile ( pred : (T) ⇒ Boolean ) : ParIterable[T]

    Drops all elements in the longest prefix of elements that satisfy the predicate, and returns a collection composed of the remaining elements.

    Drops all elements in the longest prefix of elements that satisfy the predicate, and returns a collection composed of the remaining elements.

    This method will use indexFlag signalling capabilities. This means that splitters may set and read the indexFlag state.

    The index flag is initially set to maximum integer value.

    pred

    the predicate used to test the elements

    returns

    a collection composed of all the elements after the longest prefix of elements in this parallel iterable that satisfy the predicate pred

    definition classes: ParIterableLikeTraversableLike
  41. def elements : Iterator[T]

    definition classes: IterableLike
    annotations: @deprecated( message = "use `iterator' instead" )
      deprecated:
    1. use iterator' instead

  42. def eq ( arg0 : AnyRef ) : Boolean

    This method is used to test whether the argument (arg0) is a reference to the receiver object (this).

    This method is used to test whether the argument (arg0) is a reference to the receiver object (this).

    The eq method implements an [http://en.wikipedia.org/wiki/Equivalence_relation equivalence relation] on non-null instances of AnyRef: * It is reflexive: for any non-null instance x of type AnyRef, x.eq(x) returns true. * It is symmetric: for any non-null instances x and y of type AnyRef, x.eq(y) returns true if and only if y.eq(x) returns true. * It is transitive: for any non-null instances x, y, and z of type AnyRef if x.eq(y) returns true and y.eq(z) returns true, then x.eq(z) returns true.

    Additionally, the eq method has three other properties. * It is consistent: for any non-null instances x and y of type AnyRef, multiple invocations of x.eq(y) consistently returns true or consistently returns false. * For any non-null instance x of type AnyRef, x.eq(null) and null.eq(x) returns false. * null.eq(null) returns true.

    When overriding the equals or hashCode methods, it is important to ensure that their behavior is consistent with reference equality. Therefore, if two objects are references to each other (o1 eq o2), they should be equal to each other (o1 == o2) and they should hash to the same value (o1.hashCode == o2.hashCode).

    arg0

    the object to compare against this object for reference equality.

    returns

    true if the argument is a reference to the receiver object; false otherwise.

    attributes: final
    definition classes: AnyRef
  43. def equals ( arg0 : Any ) : Boolean

    This method is used to compare the receiver object (this) with the argument object (arg0) for equivalence.

    This method is used to compare the receiver object (this) with the argument object (arg0) for equivalence.

    The default implementations of this method is an [http://en.wikipedia.org/wiki/Equivalence_relation equivalence relation]: * It is reflexive: for any instance x of type Any, x.equals(x) should return true. * It is symmetric: for any instances x and y of type Any, x.equals(y) should return true if and only if y.equals(x) returns true. * It is transitive: for any instances x, y, and z of type AnyRef if x.equals(y) returns true and y.equals(z) returns true, then x.equals(z) should return true.

    If you override this method, you should verify that your implementation remains an equivalence relation. Additionally, when overriding this method it is often necessary to override hashCode to ensure that objects that are "equal" (o1.equals(o2) returns true) hash to the same Int (o1.hashCode.equals(o2.hashCode)).

    arg0

    the object to compare against this object for equality.

    returns

    true if the receiver object is equivalent to the argument; false otherwise.

    definition classes: AnyRef → Any
  44. def exists ( pred : (T) ⇒ Boolean ) : Boolean

    Tests whether a predicate holds for some element of this parallel iterable.

    Tests whether a predicate holds for some element of this parallel iterable.

    This method will use abort signalling capabilities. This means that splitters may send and read abort signals.

    returns

    true if p holds for some element, false otherwise

  45. def filter ( pred : (T) ⇒ Boolean ) : ParIterable[T]

    Selects all elements of this parallel iterable which satisfy a predicate.

    Selects all elements of this parallel iterable which satisfy a predicate.

    returns

    a new parallel iterable consisting of all elements of this parallel iterable that satisfy the given predicate p. The order of the elements is preserved.

    definition classes: ParIterableLikeTraversableLike
  46. def filterNot ( pred : (T) ⇒ Boolean ) : ParIterable[T]

    Selects all elements of this parallel iterable which do not satisfy a predicate.

    Selects all elements of this parallel iterable which do not satisfy a predicate.

    returns

    a new parallel iterable consisting of all elements of this parallel iterable that do not satisfy the given predicate p. The order of the elements is preserved.

    definition classes: ParIterableLikeTraversableLike
  47. def finalize () : Unit

    This method is called by the garbage collector on the receiver object when garbage collection determines that there are no more references to the object.

    This method is called by the garbage collector on the receiver object when garbage collection determines that there are no more references to the object.

    The details of when and if the finalize method are invoked, as well as the interaction between finalize and non-local returns and exceptions, are all platform dependent.

    attributes: protected[lang]
    definition classes: AnyRef
    annotations: @throws()
  48. def find ( pred : (T) ⇒ Boolean ) : Option[T]

    Finds some element in the collection for which the predicate holds, if such an element exists.

    Finds some element in the collection for which the predicate holds, if such an element exists. The element may not necessarily be the first such element in the iteration order.

    If there are multiple elements obeying the predicate, the choice is nondeterministic.

    This method will use abort signalling capabilities. This means that splitters may send and read abort signals.

    returns

    an option value with the element if such an element exists, or None otherwise

  49. def first : T

    definition classes: IterableLike
    annotations: @deprecated( message = "use `head' instead" )
      deprecated:
    1. use head' instead

  50. def firstOption : Option[T]

    None if iterable is empty.

    None if iterable is empty.

    definition classes: IterableLike
    annotations: @deprecated( message = "use `headOption' instead" )
      deprecated:
    1. use headOption' instead

  51. def flatMap [B] ( f : (T) ⇒ TraversableOnce[B] ) : ParIterable[B]

    [use case] Builds a new collection by applying a function to all elements of this parallel iterable and concatenating the results.

    [use case]

    Builds a new collection by applying a function to all elements of this parallel iterable and concatenating the results.

    B

    the element type of the returned collection.

    f

    the function to apply to each element.

    returns

    a new parallel iterable resulting from applying the given collection-valued function f to each element of this parallel iterable and concatenating the results.

    attributes: abstract
    definition classes: TraversableLike
  52. def flatMap [S, That] ( f : (T) ⇒ TraversableOnce[S] )(implicit bf : CanBuildFrom[ParIterable[T], S, That] ) : That

    Builds a new collection by applying a function to all elements of this parallel iterable and concatenating the results.

    Builds a new collection by applying a function to all elements of this parallel iterable and concatenating the results.

    That

    the class of the returned collection. Where possible, That is the same class as the current collection class Repr, but this depends on the element type B being admissible for that class, which means that an implicit instance of type CanBuildFrom[Repr, B, That] is found.

    f

    the function to apply to each element.

    bf

    an implicit value of class CanBuildFrom which determines the result class That from the current representation type Repr and and the new element type B.

    returns

    a new collection of type That resulting from applying the given collection-valued function f to each element of this parallel iterable and concatenating the results.

    definition classes: ParIterableLikeTraversableLikeFilterMonadic
  53. def flatten [B] : ParIterable[B]

    [use case] Converts this parallel iterable of traversable collections into a parallel iterable in which all element collections are concatenated.

    [use case]

    Converts this parallel iterable of traversable collections into a parallel iterable in which all element collections are concatenated.

    B

    the type of the elements of each traversable collection.

    returns

    a new parallel iterable resulting from concatenating all element parallel iterables.

    attributes: abstract
    definition classes: GenericTraversableTemplate
  54. def flatten [B] (implicit asTraversable : (T) ⇒ TraversableOnce[B] ) : ParIterable[B]

    Converts this parallel iterable of traversable collections into a parallel iterable in which all element collections are concatenated.

    Converts this parallel iterable of traversable collections into a parallel iterable in which all element collections are concatenated.

    B

    the type of the elements of each traversable collection.

    asTraversable

    an implicit conversion which asserts that the element type of this parallel iterable is a Traversable.

    returns

    a new parallel iterable resulting from concatenating all element parallel iterables.

    definition classes: GenericTraversableTemplate
  55. def fold [U >: T] ( z : U )( op : (U, U) ⇒ U ) : U

    Folds the elements of this sequence using the specified associative binary operator.

    Folds the elements of this sequence using the specified associative binary operator. The order in which the elements are reduced is unspecified and may be nondeterministic.

    Note this method has a different signature than the foldLeft and foldRight methods of the trait Traversable. The result of folding may only be a supertype of this parallel collection's type parameter T.

    U

    a type parameter for the binary operator, a supertype of T.

    z

    a neutral element for the fold operation, it may be added to the result an arbitrary number of times, not changing the result (e.g. Nil for list concatenation, 0 for addition, or 1 for multiplication)

    op

    a binary operator that must be associative

    returns

    the result of applying fold operator op between all the elements and z

    definition classes: ParIterableLike
  56. def foldLeft [S] ( z : S )( op : (S, T) ⇒ S ) : S

    Applies a binary operator to a start value and all elements of this parallel iterable, going left to right.

    Applies a binary operator to a start value and all elements of this parallel iterable, going left to right.

    Note: will not terminate for infinite-sized collections.

    Note: might return different results for different runs, unless the underlying collection type is ordered. or the operator is associative and commutative.

    z

    the start value.

    op

    the binary operator.

    returns

    the result of inserting op between consecutive elements of this parallel iterable, going left to right with the start value z on the left:

                op(...op(z, x,,1,,), x,,2,,, ..., x,,n,,)
    

    where x,,1,,, ..., x,,n,, are the elements of this parallel iterable.

    definition classes: ParIterableLikeTraversableOnce
  57. def foldRight [S] ( z : S )( op : (T, S) ⇒ S ) : S

    Applies a binary operator to all elements of this parallel iterable and a start value, going right to left.

    Applies a binary operator to all elements of this parallel iterable and a start value, going right to left.

    Note: will not terminate for infinite-sized collections.

    Note: might return different results for different runs, unless the underlying collection type is ordered. or the operator is associative and commutative.

    z

    the start value.

    op

    the binary operator.

    returns

    the result of inserting op between consecutive elements of this parallel iterable, going right to left with the start value z on the right:

                op(x,,1,,, op(x,,2,,, ... op(x,,n,,, z)...))
    

    where x,,1,,, ..., x,,n,, are the elements of this parallel iterable.

    definition classes: ParIterableLikeIterableLikeTraversableOnce
  58. def forall ( pred : (T) ⇒ Boolean ) : Boolean

    Tests whether a predicate holds for all elements of this parallel iterable.

    Tests whether a predicate holds for all elements of this parallel iterable.

    This method will use abort signalling capabilities. This means that splitters may send and read abort signals.

    returns

    true if p holds for all elements, false otherwise

  59. def foreach [U] ( f : (T) ⇒ U ) : Unit

    Applies a function f to all the elements of parallel iterable in a sequential order.

    Applies a function f to all the elements of parallel iterable in a sequential order.

    U

    the result type of the function applied to each element, which is always discarded

    f

    function applied to each element

  60. def genericBuilder [B] : Combiner[B, ParIterable[B]]

    The generic builder that builds instances of ParIterable at arbitrary element types.

    The generic builder that builds instances of ParIterable at arbitrary element types.

  61. def genericCombiner [B] : Combiner[B, ParIterable[B]]

    definition classes: GenericParTemplate
  62. def getClass () : java.lang.Class[_ <: java.lang.Object]

    Returns a representation that corresponds to the dynamic class of the receiver object.

    Returns a representation that corresponds to the dynamic class of the receiver object.

    The nature of the representation is platform dependent.

    returns

    a representation that corresponds to the dynamic class of the receiver object.

    attributes: final
    definition classes: AnyRef
  63. def groupBy [K] ( f : (T) ⇒ K ) : ParMap[K, ParIterable[T]]

    Partitions this parallel iterable into a map of parallel iterables according to some discriminator function.

    Partitions this parallel iterable into a map of parallel iterables according to some discriminator function.

    Note: this method is not re-implemented by views. This means when applied to a view it will always force the view and return a new parallel iterable.

    K

    the type of keys returned by the discriminator function.

    f

    the discriminator function.

    returns

    A map from keys to parallel iterables such that the following invariant holds:

                    (xs partition f)(k) = xs filter (x => f(x) == k)
    

    That is, every key k is bound to a parallel iterable of those elements x for which f(x) equals k.

    definition classes: ParIterableLikeTraversableLike
  64. def grouped ( size : Int ) : Iterator[ParIterable[T]]

    Partitions elements in fixed size parallel iterables.

    Partitions elements in fixed size parallel iterables.

    size

    the number of elements per group

    returns

    An iterator producing parallel iterables of size size, except the last will be truncated if the elements don't divide evenly.

    definition classes: IterableLike
      see also:
    1. Iterator#grouped

  65. def hasDefiniteSize : Boolean

    Tests whether this parallel iterable is known to have a finite size.

    Tests whether this parallel iterable is known to have a finite size. All strict collections are known to have finite size. For a non-strict collection such as Stream, the predicate returns true if all elements have been computed. It returns false if the stream is not yet evaluated to the end.

    Note: many collection methods will not work on collections of infinite sizes.

    returns

    true if this collection is known to have finite size, false otherwise.

    definition classes: TraversableLikeTraversableOnce
  66. def hashCode () : Int

    Returns a hash code value for the object.

    Returns a hash code value for the object.

    The default hashing algorithm is platform dependent.

    Note that it is allowed for two objects to have identical hash codes (o1.hashCode.equals(o2.hashCode)) yet not be equal (o1.equals(o2) returns false). A degenerate implementation could always return 0. However, it is required that if two objects are equal (o1.equals(o2) returns true) that they have identical hash codes (o1.hashCode.equals(o2.hashCode)). Therefore, when overriding this method, be sure to verify that the behavior is consistent with the equals method.

    returns

    the hash code value for the object.

    definition classes: AnyRef → Any
  67. def head : T

    Selects the first element of this parallel iterable.

    Selects the first element of this parallel iterable.

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    returns

    the first element of this parallel iterable.

    definition classes: IterableLikeTraversableLike
  68. def headOption : Option[T]

    Optionally selects the first element.

    Optionally selects the first element.

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    returns

    the first element of this parallel iterable if it is nonempty, None if it is empty.

    definition classes: TraversableLike
  69. def init : ParIterable[T]

    Selects all elements except the last.

    Selects all elements except the last.

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    returns

    a parallel iterable consisting of all elements of this parallel iterable except the last one.

    definition classes: TraversableLike
  70. def inits : Iterator[ParIterable[T]]

    Iterates over the inits of this parallel iterable.

    Iterates over the inits of this parallel iterable. The first value will be this parallel iterable and the final one will be an empty parallel iterable, with the intervening values the results of successive applications of init.

    returns

    an iterator over all the inits of this parallel iterable

    definition classes: TraversableLike
    Example :
    1. List(1,2,3).inits = Iterator(List(1,2,3), List(1,2), List(1), Nil)

  71. def isEmpty : Boolean

    Tests whether this parallel iterable is empty.

    Tests whether this parallel iterable is empty.

    returns

    true if the parallel iterable contain no elements, false otherwise.

    definition classes: IterableLikeTraversableLikeTraversableOnce
  72. def isInstanceOf [T0] : Boolean

    This method is used to test whether the dynamic type of the receiver object is T0.

    This method is used to test whether the dynamic type of the receiver object is T0.

    Note that the test result of the test is modulo Scala's erasure semantics. Therefore the expression 1.isInstanceOf[String] will return false, while the expression List(1).isInstanceOf[List[String]] will return true. In the latter example, because the type argument is erased as part of compilation it is not possible to check whether the contents of the list are of the requested typed.

    returns

    true if the receiver object is an instance of erasure of type T0; false otherwise.

    attributes: final
    definition classes: Any
  73. def isStrictSplitterCollection : Boolean

    Denotes whether this parallel collection has strict splitters.

    Denotes whether this parallel collection has strict splitters.

    This is true in general, and specific collection instances may choose to override this method. Such collections will fail to execute methods which rely on splitters being strict, i.e. returning a correct value in the remaining method.

    This method helps ensure that such failures occur on method invocations, rather than later on and in unpredictable ways.

    definition classes: ParIterableLike
  74. def isTraversableAgain : Boolean

    Tests whether this parallel iterable can be repeatedly traversed.

    Tests whether this parallel iterable can be repeatedly traversed.

    returns

    true

    attributes: final
    definition classes: TraversableLikeTraversableOnce
  75. def iterator : Splitter[T]

    Creates a new split iterator used to traverse the elements of this collection.

    Creates a new split iterator used to traverse the elements of this collection.

    By default, this method is implemented in terms of the protected parallelIterator method.

    returns

    a split iterator

    definition classes: ParIterableLikeIterableLike
  76. def last : T

    Selects the last element.

    Selects the last element.

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    returns

    The last element of this parallel iterable.

    definition classes: TraversableLike
  77. def lastOption : Option[T]

    Optionally selects the last element.

    Optionally selects the last element.

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    returns

    the last element of this parallel iterable$ if it is nonempty, None if it is empty.

    definition classes: TraversableLike
  78. def map [B] ( f : (T) ⇒ B ) : ParIterable[B]

    [use case] Builds a new collection by applying a function to all elements of this parallel iterable.

    [use case]

    Builds a new collection by applying a function to all elements of this parallel iterable.

    B

    the element type of the returned collection.

    f

    the function to apply to each element.

    returns

    a new parallel iterable resulting from applying the given function f to each element of this parallel iterable and collecting the results.

    attributes: abstract
    definition classes: TraversableLike
  79. def map [S, That] ( f : (T) ⇒ S )(implicit bf : CanBuildFrom[ParIterable[T], S, That] ) : That

    Builds a new collection by applying a function to all elements of this parallel iterable.

    Builds a new collection by applying a function to all elements of this parallel iterable.

    That

    the class of the returned collection. Where possible, That is the same class as the current collection class Repr, but this depends on the element type B being admissible for that class, which means that an implicit instance of type CanBuildFrom[Repr, B, That] is found.

    f

    the function to apply to each element.

    bf

    an implicit value of class CanBuildFrom which determines the result class That from the current representation type Repr and and the new element type B.

    returns

    a new collection of type That resulting from applying the given function f to each element of this parallel iterable and collecting the results.

    definition classes: ParIterableLikeTraversableLikeFilterMonadic
  80. def max : T

    [use case] Finds the largest element.

    [use case]

    Finds the largest element.

    returns

    the largest element of this parallel iterable.

    attributes: abstract
    definition classes: TraversableOnce
  81. def max [U >: T] (implicit ord : Ordering[U] ) : T

    Finds the largest element.

    Finds the largest element.

    returns

    the largest element of this parallel iterable with respect to the ordering cmp.

    definition classes: ParIterableLikeTraversableOnce
  82. def maxBy [S] ( f : (T) ⇒ S )(implicit cmp : Ordering[S] ) : T

    definition classes: ParIterableLikeTraversableOnce
  83. def min : T

    [use case] Finds the smallest element.

    [use case]

    Finds the smallest element.

    returns

    the smallest element of this parallel iterable

    attributes: abstract
    definition classes: TraversableOnce
  84. def min [U >: T] (implicit ord : Ordering[U] ) : T

    Finds the smallest element.

    Finds the smallest element.

    returns

    the smallest element of this parallel iterable with respect to the ordering cmp.

    definition classes: ParIterableLikeTraversableOnce
  85. def minBy [S] ( f : (T) ⇒ S )(implicit cmp : Ordering[S] ) : T

    definition classes: ParIterableLikeTraversableOnce
  86. def mkString : String

    Displays all elements of this parallel iterable in a string.

    Displays all elements of this parallel iterable in a string.

    returns

    a string representation of this parallel iterable. In the resulting string the string representations (w.r.t. the method toString) of all elements of this parallel iterable follow each other without any separator string.

    definition classes: ParIterableLikeTraversableOnce
  87. def mkString ( sep : String ) : String

    Displays all elements of this parallel iterable in a string using a separator string.

    Displays all elements of this parallel iterable in a string using a separator string.

    sep

    the separator string.

    returns

    a string representation of this parallel iterable. In the resulting string the string representations (w.r.t. the method toString) of all elements of this parallel iterable are separated by the string sep.

    definition classes: ParIterableLikeTraversableOnce
    Example :
    1. List(1, 2, 3).mkString("|") = "1|2|3"

  88. def mkString ( start : String , sep : String , end : String ) : String

    Displays all elements of this parallel iterable in a string using start, end, and separator strings.

    Displays all elements of this parallel iterable in a string using start, end, and separator strings.

    start

    the starting string.

    sep

    the separator string.

    end

    the ending string.

    returns

    a string representation of this parallel iterable. The resulting string begins with the string start and ends with the string end. Inside, the string representations (w.r.t. the method toString) of all elements of this parallel iterable are separated by the string sep.

    definition classes: ParIterableLikeTraversableOnce
    Example :
    1. List(1, 2, 3).mkString("(", "; ", ")") = "(1; 2; 3)"

  89. def ne ( arg0 : AnyRef ) : Boolean

    o.ne(arg0) is the same as !(o.eq(arg0)).

    o.ne(arg0) is the same as !(o.eq(arg0)).

    arg0

    the object to compare against this object for reference dis-equality.

    returns

    false if the argument is not a reference to the receiver object; true otherwise.

    attributes: final
    definition classes: AnyRef
  90. def newBuilder : Builder[T, ParIterable[T]]

    The newBuilder operation returns a parallel builder assigned to this collection's fork/join pool.

    The newBuilder operation returns a parallel builder assigned to this collection's fork/join pool. This method forwards the call to newCombiner.

    attributes: protected[this]
    definition classes: ParIterableLikeTraversableLikeHasNewBuilder
  91. def newCombiner : Combiner[T, ParIterable[T]]

    attributes: protected[this]
    definition classes: GenericParTemplateHasNewCombiner
  92. def nonEmpty : Boolean

    Tests whether the parallel iterable is not empty.

    Tests whether the parallel iterable is not empty.

    returns

    true if the parallel iterable contains at least one element, false otherwise.

    definition classes: TraversableOnce
  93. def notify () : Unit

    Wakes up a single thread that is waiting on the receiver object's monitor.

    Wakes up a single thread that is waiting on the receiver object's monitor.

    attributes: final
    definition classes: AnyRef
  94. def notifyAll () : Unit

    Wakes up all threads that are waiting on the receiver object's monitor.

    Wakes up all threads that are waiting on the receiver object's monitor.

    attributes: final
    definition classes: AnyRef
  95. def par : ParIterable[T]

    Returns a parallel implementation of this collection.

    Returns a parallel implementation of this collection.

    For most collection types, this method creates a new parallel collection by copying all the elements. For these collection, par takes linear time. Mutable collections in this category do not produce a mutable parallel collection that has the same underlying dataset, so changes in one collection will not be reflected in the other one.

    Specific collections (e.g. ParArray or mutable.ParHashMap) override this default behaviour by creating a parallel collection which shares the same underlying dataset. For these collections, par takes constant or sublinear time.

    All parallel collections return a reference to themselves.

    returns

    a parallel implementation of this collection

  96. def parCombiner : Combiner[T, ParIterable[T]]

    The default par implementation uses the combiner provided by this method to create a new parallel collection.

    The default par implementation uses the combiner provided by this method to create a new parallel collection.

    returns

    a combiner for the parallel collection of type ParRepr

    attributes: protected[this]
  97. def parallelIterator : ParIterableIterator[T]

    Creates a new parallel iterator used to traverse the elements of this parallel collection.

    Creates a new parallel iterator used to traverse the elements of this parallel collection. This iterator is more specific than the iterator of the returned by iterator, and augmented with additional accessor and transformer methods.

    returns

    a parallel iterator

    attributes: abstract
    definition classes: ParIterableLike
  98. def partition ( pred : (T) ⇒ Boolean ) : (ParIterable[T], ParIterable[T])

    Partitions this parallel iterable in two parallel iterables according to a predicate.

    Partitions this parallel iterable in two parallel iterables according to a predicate.

    returns

    a pair of parallel iterables: the first parallel iterable consists of all elements that satisfy the predicate p and the second parallel iterable consists of all elements that don't. The relative order of the elements in the resulting parallel iterables is the same as in the original parallel iterable.

    definition classes: ParIterableLikeTraversableLike
  99. def product : T

    [use case] Multiplies up the elements of this collection.

    [use case]

    Multiplies up the elements of this collection.

    returns

    the product of all elements in this parallel iterable of numbers of type Int. Instead of Int, any other type T with an implicit Numeric[T] implementation can be used as element type of the parallel iterable and as result type of product. Examples of such types are: Long, Float, Double, BigInt.

    attributes: abstract
    definition classes: TraversableOnce
  100. def product [U >: T] (implicit num : Numeric[U] ) : U

    Multiplies up the elements of this collection.

    Multiplies up the elements of this collection.

    num

    an implicit parameter defining a set of numeric operations which includes the * operator to be used in forming the product.

    returns

    the product of all elements of this parallel iterable with respect to the * operator in num.

    definition classes: ParIterableLikeTraversableOnce
  101. def projection : IterableView[T, ParIterable[T]]

    returns a projection that can be used to call non-strict filter, map, and flatMap methods that build projections of the collection.

    returns a projection that can be used to call non-strict filter, map, and flatMap methods that build projections of the collection.

    definition classes: IterableLike
    annotations: @deprecated( message = "use `view' instead" )
      deprecated:
    1. use view' instead

  102. def reduce [U >: T] ( op : (U, U) ⇒ U ) : U

    Reduces the elements of this sequence using the specified associative binary operator.

    Reduces the elements of this sequence using the specified associative binary operator.

    The order in which the operations on elements are performed is unspecified and may be nondeterministic.

    Note this method has a different signature than the reduceLeft and reduceRight methods of the trait Traversable. The result of reducing may only be a supertype of this parallel collection's type parameter T.

    U

    A type parameter for the binary operator, a supertype of T.

    op

    A binary operator that must be associative.

    returns

    The result of applying reduce operator op between all the elements if the collection is nonempty.

    definition classes: ParIterableLike
  103. def reduceLeft [U >: T] ( op : (U, T) ⇒ U ) : U

    Applies a binary operator to all elements of this parallel iterable, going left to right.

    Applies a binary operator to all elements of this parallel iterable, going left to right.

    Note: will not terminate for infinite-sized collections.

    Note: might return different results for different runs, unless the underlying collection type is ordered. or the operator is associative and commutative.

    op

    the binary operator.

    returns

    the result of inserting op between consecutive elements of this parallel iterable, going left to right:

                op(...(op(x,,1,,, x,,2,,), ... ) , x,,n,,)
    

    where x,,1,,, ..., x,,n,, are the elements of this parallel iterable.

    definition classes: ParIterableLikeTraversableOnce
  104. def reduceLeftOption [B >: T] ( op : (B, T) ⇒ B ) : Option[B]

    Optionally applies a binary operator to all elements of this parallel iterable, going left to right.

    Optionally applies a binary operator to all elements of this parallel iterable, going left to right.

    Note: will not terminate for infinite-sized collections.

    Note: might return different results for different runs, unless the underlying collection type is ordered. or the operator is associative and commutative.

    B

    the result type of the binary operator.

    op

    the binary operator.

    returns

    an option value containing the result of reduceLeft(op) is this parallel iterable is nonempty, None otherwise.

    definition classes: TraversableOnce
  105. def reduceOption [U >: T] ( op : (U, U) ⇒ U ) : Option[U]

    Optionally reduces the elements of this sequence using the specified associative binary operator.

    Optionally reduces the elements of this sequence using the specified associative binary operator.

    The order in which the operations on elements are performed is unspecified and may be nondeterministic.

    Note this method has a different signature than the reduceLeftOption and reduceRightOption methods of the trait Traversable. The result of reducing may only be a supertype of this parallel collection's type parameter T.

    U

    A type parameter for the binary operator, a supertype of T.

    op

    A binary operator that must be associative.

    returns

    An option value containing result of applying reduce operator op between all the elements if the collection is nonempty, and None otherwise.

    definition classes: ParIterableLike
  106. def reduceRight [U >: T] ( op : (T, U) ⇒ U ) : U

    Applies a binary operator to all elements of this parallel iterable, going right to left.

    Applies a binary operator to all elements of this parallel iterable, going right to left.

    Note: will not terminate for infinite-sized collections.

    Note: might return different results for different runs, unless the underlying collection type is ordered. or the operator is associative and commutative.

    op

    the binary operator.

    returns

    the result of inserting op between consecutive elements of this parallel iterable, going right to left:

                op(x,,1,,, op(x,,2,,, ..., op(x,,n-1,,, x,,n,,)...))
    

    where x,,1,,, ..., x,,n,, are the elements of this parallel iterable.

    definition classes: ParIterableLikeIterableLikeTraversableOnce
  107. def reduceRightOption [B >: T] ( op : (T, B) ⇒ B ) : Option[B]

    Optionally applies a binary operator to all elements of this parallel iterable, going right to left.

    Optionally applies a binary operator to all elements of this parallel iterable, going right to left.

    Note: will not terminate for infinite-sized collections.

    Note: might return different results for different runs, unless the underlying collection type is ordered. or the operator is associative and commutative.

    B

    the result type of the binary operator.

    op

    the binary operator.

    returns

    an option value containing the result of reduceRight(op) is this parallel iterable is nonempty, None otherwise.

    definition classes: TraversableOnce
  108. def repr : ParIterable[T]

    The collection of type parallel iterable underlying this TraversableLike object.

    The collection of type parallel iterable underlying this TraversableLike object. By default this is implemented as the TraversableLike object itself, but this can be overridden.

    definition classes: TraversableLike
  109. def reuse [S, That] ( oldc : Option[Combiner[S, That]] , newc : Combiner[S, That] ) : Combiner[S, That]

    Optionally reuses an existing combiner for better performance.

    Optionally reuses an existing combiner for better performance. By default it doesn't - subclasses may override this behaviour. The provided combiner oldc that can potentially be reused will be either some combiner from the previous computational task, or None if there was no previous phase (in which case this method must return newc).

    oldc

    The combiner that is the result of the previous task, or None if there was no previous task.

    newc

    The new, empty combiner that can be used.

    returns

    Either newc or oldc.

    attributes: protected
    definition classes: ParIterableLike
  110. def reversed : List[T]

    attributes: protected[this]
    definition classes: TraversableOnce
  111. def sameElements ( that : Iterable[T] ) : Boolean

    [use case] Checks if the other iterable collection contains the same elements in the same order as this parallel iterable.

    [use case]

    Checks if the other iterable collection contains the same elements in the same order as this parallel iterable.

    that

    the collection to compare with.

    returns

    true, if both collections contain the same elements in the same order, false otherwise.

    attributes: abstract
    definition classes: IterableLike
  112. def sameElements [B >: T] ( that : Iterable[B] ) : Boolean

    Checks if the other iterable collection contains the same elements in the same order as this parallel iterable.

    Checks if the other iterable collection contains the same elements in the same order as this parallel iterable.

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    Note: will not terminate for infinite-sized collections.

    B

    the type of the elements of collection that.

    that

    the collection to compare with.

    returns

    true, if both collections contain the same elements in the same order, false otherwise.

    definition classes: IterableLike
  113. def scan ( z : T )( op : (T, T) ⇒ T ) : ParIterable[T]

    [use case] Computes a prefix scan of the elements of the collection.

    [use case]

    Computes a prefix scan of the elements of the collection.

    z

    neutral element for the operator op

    op

    the associative operator for the scan

    returns

    a new parallel iterable containing the prefix scan of the elements in this parallel iterable

    attributes: abstract
    definition classes: ParIterableLike
  114. def scan [U >: T, That] ( z : U )( op : (U, U) ⇒ U )(implicit cbf : CanCombineFrom[ParIterable[T], U, That] ) : That

    Computes a prefix scan of the elements of the collection.

    Computes a prefix scan of the elements of the collection.

    Note: The neutral element z may be applied more than once.

    U

    element type of the resulting collection

    That

    type of the resulting collection

    z

    neutral element for the operator op

    op

    the associative operator for the scan

    cbf

    combiner factory which provides a combiner

    returns

    a collection containing the prefix scan of the elements in the original collection

    definition classes: ParIterableLike
  115. def scanBlockSize : Int

    attributes: protected[this]
    definition classes: ParIterableLike
  116. def scanLeft [B, That] ( z : B )( op : (B, T) ⇒ B )(implicit bf : CanBuildFrom[ParIterable[T], B, That] ) : That

    Produces a collection containing cummulative results of applying the operator going left to right.

    Produces a collection containing cummulative results of applying the operator going left to right.

    Note: will not terminate for infinite-sized collections.

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    B

    the type of the elements in the resulting collection

    That

    the actual type of the resulting collection

    z

    the initial value

    op

    the binary operator applied to the intermediate result and the element

    bf

    an implicit value of class CanBuildFrom which determines the result class That from the current representation type Repr and and the new element type B.

    returns

    collection with intermediate results

    definition classes: TraversableLike
  117. def scanRight [B, That] ( z : B )( op : (T, B) ⇒ B )(implicit bf : CanBuildFrom[ParIterable[T], B, That] ) : That

    Produces a collection containing cummulative results of applying the operator going right to left.

    Produces a collection containing cummulative results of applying the operator going right to left. The head of the collection is the last cummulative result.

    Note: will not terminate for infinite-sized collections.

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    Example:

       List(1, 2, 3, 4).scanRight(0)(_ + _) == List(10, 9, 7, 4, 0)
    
    B

    the type of the elements in the resulting collection

    That

    the actual type of the resulting collection

    z

    the initial value

    op

    the binary operator applied to the intermediate result and the element

    bf

    an implicit value of class CanBuildFrom which determines the result class That from the current representation type Repr and and the new element type B.

    returns

    collection with intermediate results

    definition classes: TraversableLike
    annotations: @migration( 2 , 9 , ... )
  118. def seq : Iterable[T]

    A version of this collection with all of the operations implemented sequentially (i.

    A version of this collection with all of the operations implemented sequentially (i.e. in a single-threaded manner).

    This method returns a reference to this collection. In parallel collections, it is redefined to return a sequential implementation of this collection. In both cases, it has O(1) complexity.

    returns

    a sequential view of the collection.

    definition classes: ParIterableLikeTraversableOnce
  119. def size : Int

    The size of this parallel iterable.

    The size of this parallel iterable.

    Note: will not terminate for infinite-sized collections.

    returns

    the number of elements in this parallel iterable.

    definition classes: TraversableOnce
  120. def slice ( unc_from : Int , unc_until : Int ) : ParIterable[T]

    Selects an interval of elements.

    Selects an interval of elements. The returned collection is made up of all elements x which satisfy the invariant:

       from <= indexOf(x) < until
    

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    returns

    a parallel iterable containing the elements greater than or equal to index from extending up to (but not including) index until of this parallel iterable.

    definition classes: ParIterableLikeIterableLikeTraversableLike
  121. def sliding [B >: T] ( size : Int , step : Int ) : Iterator[ParIterable[T]]

    definition classes: IterableLike
  122. def sliding [B >: T] ( size : Int ) : Iterator[ParIterable[T]]

    Groups elements in fixed size blocks by passing a "sliding window" over them (as opposed to partitioning them, as is done in grouped.

    Groups elements in fixed size blocks by passing a "sliding window" over them (as opposed to partitioning them, as is done in grouped.)

    size

    the number of elements per group

    returns

    An iterator producing parallel iterables of size size, except the last and the only element will be truncated if there are fewer elements than size.

    definition classes: IterableLike
      see also:
    1. Iterator#sliding

  123. def span ( pred : (T) ⇒ Boolean ) : (ParIterable[T], ParIterable[T])

    Splits this parallel iterable into a prefix/suffix pair according to a predicate.

    Splits this parallel iterable into a prefix/suffix pair according to a predicate.

    This method will use indexFlag signalling capabilities. This means that splitters may set and read the indexFlag state.

    The index flag is initially set to maximum integer value.

    pred

    the predicate used to test the elements

    returns

    a pair consisting of the longest prefix of the collection for which all the elements satisfy pred, and the rest of the collection

    definition classes: ParIterableLikeTraversableLike
  124. def splitAt ( n : Int ) : (ParIterable[T], ParIterable[T])

    Splits this parallel iterable into two at a given position.

    Splits this parallel iterable into two at a given position. Note: c splitAt n is equivalent to (but possibly more efficient than) (c take n, c drop n).

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    n

    the position at which to split.

    returns

    a pair of parallel iterables consisting of the first n elements of this parallel iterable, and the other elements.

    definition classes: ParIterableLikeTraversableLike
  125. def stringPrefix : String

    Defines the prefix of this object's toString representation.

    Defines the prefix of this object's toString representation.

    returns

    a string representation which starts the result of toString applied to this parallel iterable. By default the string prefix is the simple name of the collection class parallel iterable.

    definition classes: TraversableLike
  126. def sum : T

    [use case] Sums up the elements of this collection.

    [use case]

    Sums up the elements of this collection.

    returns

    the sum of all elements in this parallel iterable of numbers of type Int. Instead of Int, any other type T with an implicit Numeric[T] implementation can be used as element type of the parallel iterable and as result type of sum. Examples of such types are: Long, Float, Double, BigInt.

    attributes: abstract
    definition classes: TraversableOnce
  127. def sum [U >: T] (implicit num : Numeric[U] ) : U

    Sums up the elements of this collection.

    Sums up the elements of this collection.

    num

    an implicit parameter defining a set of numeric operations which includes the + operator to be used in forming the sum.

    returns

    the sum of all elements of this parallel iterable with respect to the + operator in num.

    definition classes: ParIterableLikeTraversableOnce
  128. def synchronized [T0] ( arg0 : ⇒ T0 ) : T0

    attributes: final
    definition classes: AnyRef
  129. def tail : ParIterable[T]

    Selects all elements except the first.

    Selects all elements except the first.

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    returns

    a parallel iterable consisting of all elements of this parallel iterable except the first one.

    definition classes: TraversableLike
  130. def tails : Iterator[ParIterable[T]]

    Iterates over the tails of this parallel iterable.

    Iterates over the tails of this parallel iterable. The first value will be this parallel iterable and the final one will be an empty parallel iterable, with the intervening values the results of successive applications of tail.

    returns

    an iterator over all the tails of this parallel iterable

    definition classes: TraversableLike
    Example :
    1. List(1,2,3).tails = Iterator(List(1,2,3), List(2,3), List(3), Nil)

  131. def take ( n : Int ) : ParIterable[T]

    Selects first n elements.

    Selects first n elements.

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    n

    Tt number of elements to take from this parallel iterable.

    returns

    a parallel iterable consisting only of the first n elements of this parallel iterable, or else the whole parallel iterable, if it has less than n elements.

    definition classes: ParIterableLikeTraversableLike
  132. def takeRight ( n : Int ) : ParIterable[T]

    Selects last n elements.

    Selects last n elements.

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    n

    the number of elements to take

    returns

    a parallel iterable consisting only of the last n elements of this parallel iterable, or else the whole parallel iterable, if it has less than n elements.

    definition classes: IterableLike
  133. def takeWhile ( pred : (T) ⇒ Boolean ) : ParIterable[T]

    Takes the longest prefix of elements that satisfy the predicate.

    Takes the longest prefix of elements that satisfy the predicate.

    This method will use indexFlag signalling capabilities. This means that splitters may set and read the indexFlag state.

    The index flag is initially set to maximum integer value.

    pred

    the predicate used to test the elements

    returns

    the longest prefix of this parallel iterable of elements that satisy the predicate pred

    definition classes: ParIterableLikeIterableLikeTraversableLike
  134. implicit def task2ops [R, Tp] ( tsk : SSCTask[R, Tp] ) : TaskOps[R, Tp]

    attributes: protected implicit
    definition classes: ParIterableLike
  135. def thisCollection : Iterable[T]

    The underlying collection seen as an instance of ParIterable.

    The underlying collection seen as an instance of ParIterable. By default this is implemented as the current collection object itself, but this can be overridden.

    attributes: protected[this]
    definition classes: IterableLikeTraversableLike
  136. def threshold ( sz : Int , p : Int ) : Int

    Some minimal number of elements after which this collection should be handled sequentially by different processors.

    Some minimal number of elements after which this collection should be handled sequentially by different processors.

    This method depends on the size of the collection and the parallelism level, which are both specified as arguments.

    sz

    the size based on which to compute the threshold

    p

    the parallelism level based on which to compute the threshold

    returns

    the maximum number of elements for performing operations sequentially

    definition classes: ParIterableLike
  137. def toArray : Array[T]

    [use case] Converts this parallel iterable to an array.

    [use case]

    Converts this parallel iterable to an array.

    Note: will not terminate for infinite-sized collections.

    returns

    an array containing all elements of this parallel iterable. A ClassManifest must be available for the element type of this parallel iterable.

    attributes: abstract
    definition classes: TraversableOnce
  138. def toArray [U >: T] (implicit arg0 : ClassManifest[U] ) : Array[U]

    Converts this parallel iterable to an array.

    Converts this parallel iterable to an array.

    Note: will not terminate for infinite-sized collections.

    returns

    an array containing all elements of this parallel iterable.

    definition classes: ParIterableLikeTraversableOnce
  139. def toBuffer [U >: T] : Buffer[U]

    Converts this parallel iterable to a mutable buffer.

    Converts this parallel iterable to a mutable buffer.

    Note: will not terminate for infinite-sized collections.

    returns

    a buffer containing all elements of this parallel iterable.

    definition classes: ParIterableLikeTraversableOnce
  140. def toCollection ( repr : ParIterable[T] ) : Iterable[T]

    A conversion from collections of type Repr to ParIterable objects.

    A conversion from collections of type Repr to ParIterable objects. By default this is implemented as just a cast, but this can be overridden.

    attributes: protected[this]
    definition classes: IterableLikeTraversableLike
  141. def toIndexedSeq [U >: T] : IndexedSeq[U]

    Converts this parallel iterable to an indexed sequence.

    Converts this parallel iterable to an indexed sequence.

    Note: will not terminate for infinite-sized collections.

    returns

    an indexed sequence containing all elements of this parallel iterable.

    definition classes: ParIterableLikeTraversableOnce
  142. def toIterable : ParIterable[T]

    Converts this parallel iterable to an iterable collection.

    Converts this parallel iterable to an iterable collection. Note that the choice of target Iterable is lazy in this default implementation as this TraversableOnce may be lazy and unevaluated (i.e. it may be an iterator which is only traversable once).

    Note: will not terminate for infinite-sized collections.

    returns

    an Iterable containing all elements of this parallel iterable.

    definition classes: ParIterableParIterableLikeIterableLikeTraversableOnce
  143. def toIterator : Iterator[T]

    Returns an Iterator over the elements in this parallel iterable.

    Returns an Iterator over the elements in this parallel iterable. Will return the same Iterator if this instance is already an Iterator.

    Note: will not terminate for infinite-sized collections.

    returns

    an Iterator containing all elements of this parallel iterable.

    definition classes: ParIterableLikeTraversableLikeTraversableOnce
  144. def toList : List[T]

    Converts this parallel iterable to a list.

    Converts this parallel iterable to a list.

    Note: will not terminate for infinite-sized collections.

    returns

    a list containing all elements of this parallel iterable.

    definition classes: ParIterableLikeTraversableOnce
  145. def toMap [T, U] : Map[T, U]

    [use case] Converts this parallel iterable to a map.

    [use case]

    Converts this parallel iterable to a map. This method is unavailable unless the elements are members of Tuple2, each ((T, U)) becoming a key-value pair in the map. Duplicate keys will be overwritten by later keys: if this is an unordered collection, which key is in the resulting map is undefined.

    Note: will not terminate for infinite-sized collections.

    returns

    a map of type immutable.Map[T, U] containing all key/value pairs of type (T, U) of this parallel iterable.

    attributes: abstract
    definition classes: TraversableOnce
  146. def toMap [K, V] (implicit ev : <:<[T, (K, V)] ) : ParMap[K, V]

    Converts this parallel iterable to a map.

    Converts this parallel iterable to a map. This method is unavailable unless the elements are members of Tuple2, each ((T, U)) becoming a key-value pair in the map. Duplicate keys will be overwritten by later keys: if this is an unordered collection, which key is in the resulting map is undefined.

    Note: will not terminate for infinite-sized collections.

    returns

    a map containing all elements of this parallel iterable.

    definition classes: ParIterableLikeTraversableOnce
  147. def toParCollection [U >: T, That] ( cbf : () ⇒ Combiner[U, That] ) : That

    attributes: protected
    definition classes: ParIterableLike
  148. def toParMap [K, V, That] ( cbf : () ⇒ Combiner[(K, V), That] )(implicit ev : <:<[T, (K, V)] ) : That

    attributes: protected
    definition classes: ParIterableLike
  149. def toSeq : ParSeq[T]

    Converts this parallel iterable to a sequence.

    Converts this parallel iterable to a sequence. As with toIterable, it's lazy in this default implementation, as this TraversableOnce may be lazy and unevaluated.

    Note: will not terminate for infinite-sized collections.

    returns

    a sequence containing all elements of this parallel iterable.

    definition classes: ParIterableParIterableLikeTraversableOnce
  150. def toSet [U >: T] : ParSet[U]

    Converts this parallel iterable to a set.

    Converts this parallel iterable to a set.

    Note: will not terminate for infinite-sized collections.

    returns

    a set containing all elements of this parallel iterable.

    definition classes: ParIterableLikeTraversableOnce
  151. def toStream : Stream[T]

    Converts this parallel iterable to a stream.

    Converts this parallel iterable to a stream.

    Note: will not terminate for infinite-sized collections.

    returns

    a stream containing all elements of this parallel iterable.

  152. def toString () : String

    Converts this parallel iterable to a string.

    Converts this parallel iterable to a string.

    returns

    a string representation of this collection. By default this string consists of the stringPrefix of this parallel iterable, followed by all elements separated by commas and enclosed in parentheses.

    definition classes: ParIterableLikeTraversableLike → AnyRef → Any
  153. def toTraversable : Traversable[T]

    Converts this parallel iterable to an unspecified Traversable.

    Converts this parallel iterable to an unspecified Traversable. Will return the same collection if this instance is already Traversable.

    Note: will not terminate for infinite-sized collections.

    returns

    a Traversable containing all elements of this parallel iterable.

    definition classes: ParIterableLikeTraversableLikeTraversableOnce
  154. def transpose [B] (implicit asTraversable : (T) ⇒ TraversableOnce[B] ) : ParIterable[ParIterable[B]]

    Transposes this parallel iterable of traversable collections into a parallel iterable of parallel iterables.

    Transposes this parallel iterable of traversable collections into a parallel iterable of parallel iterables.

    B

    the type of the elements of each traversable collection.

    asTraversable

    an implicit conversion which asserts that the element type of this parallel iterable is a Traversable.

    returns

    a two-dimensional parallel iterable of parallel iterables which has as nth row the nth column of this parallel iterable.

    definition classes: GenericTraversableTemplate
    annotations: @migration( 2 , 9 , ... )
  155. def unzip [A1, A2] (implicit asPair : (T) ⇒ (A1, A2) ) : (ParIterable[A1], ParIterable[A2])

    Converts this parallel iterable of pairs into two collections of the first and second half of each pair.

    Converts this parallel iterable of pairs into two collections of the first and second half of each pair.

    asPair

    an implicit conversion which asserts that the element type of this parallel iterable is a pair.

    returns

    a pair parallel iterables, containing the first, respectively second half of each element pair of this parallel iterable.

    definition classes: GenericTraversableTemplate
  156. def unzip3 [A1, A2, A3] (implicit asTriple : (T) ⇒ (A1, A2, A3) ) : (ParIterable[A1], ParIterable[A2], ParIterable[A3])

    Converts this parallel iterable of triples into three collections of the first, second, and third element of each triple.

    Converts this parallel iterable of triples into three collections of the first, second, and third element of each triple.

    returns

    a triple parallel iterables, containing the first, second, respectively third member of each element triple of this parallel iterable.

    definition classes: GenericTraversableTemplate
  157. def view : ParIterableView[T, ParIterable[T], Iterable[T]]

    Creates a non-strict view of this parallel iterable.

    Creates a non-strict view of this parallel iterable.

    returns

    a non-strict view of this parallel iterable.

    definition classes: ParIterableLikeIterableLikeTraversableLike
  158. def view ( from : Int , until : Int ) : IterableView[T, ParIterable[T]]

    Creates a non-strict view of a slice of this parallel iterable.

    Creates a non-strict view of a slice of this parallel iterable.

    Note: the difference between view and slice is that view produces a view of the current parallel iterable, whereas slice produces a new parallel iterable.

    Note: view(from, to) is equivalent to view.slice(from, to)

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    from

    the index of the first element of the view

    until

    the index of the element following the view

    returns

    a non-strict view of a slice of this parallel iterable, starting at index from and extending up to (but not including) index until.

    definition classes: IterableLikeTraversableLike
  159. def wait () : Unit

    attributes: final
    definition classes: AnyRef
    annotations: @throws()
  160. def wait ( arg0 : Long , arg1 : Int ) : Unit

    attributes: final
    definition classes: AnyRef
    annotations: @throws()
  161. def wait ( arg0 : Long ) : Unit

    attributes: final
    definition classes: AnyRef
    annotations: @throws()
  162. def withFilter ( p : (T) ⇒ Boolean ) : FilterMonadic[T, ParIterable[T]]

    Creates a non-strict filter of this parallel iterable.

    Creates a non-strict filter of this parallel iterable.

    Note: the difference between c filter p and c withFilter p is that the former creates a new collection, whereas the latter only restricts the domain of subsequent map, flatMap, foreach, and withFilter operations.

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    p

    the predicate used to test elements.

    returns

    an object of class WithFilter, which supports map, flatMap, foreach, and withFilter operations. All these operations apply to those elements of this parallel iterable which satisfy the predicate p.

    definition classes: TraversableLikeFilterMonadic
  163. def wrap [R] ( body : ⇒ R ) : NonDivisible[R]

    attributes: protected
    definition classes: ParIterableLike
  164. def zip [B] ( that : Iterable[B] ) : ParIterable[(T, B)]

    [use case] Returns a parallel iterable formed from this parallel iterable and another iterable collection by combining corresponding elements in pairs.

    [use case]

    Returns a parallel iterable formed from this parallel iterable and another iterable collection by combining corresponding elements in pairs. If one of the two collections is longer than the other, its remaining elements are ignored.

    B

    the type of the second half of the returned pairs

    that

    The iterable providing the second half of each result pair

    returns

    a new parallel iterable containing pairs consisting of corresponding elements of this parallel iterable and that. The length of the returned collection is the minimum of the lengths of this parallel iterable and that.

    attributes: abstract
    definition classes: IterableLike
  165. def zip [U >: T, S, That] ( that : Iterable[S] )(implicit bf : CanBuildFrom[ParIterable[T], (U, S), That] ) : That

    Returns a parallel iterable formed from this parallel iterable and another iterable collection by combining corresponding elements in pairs.

    Returns a parallel iterable formed from this parallel iterable and another iterable collection by combining corresponding elements in pairs. If one of the two collections is longer than the other, its remaining elements are ignored.

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    That

    the class of the returned collection. Where possible, That is the same class as the current collection class Repr, but this depends on the element type (A1, B) being admissible for that class, which means that an implicit instance of type CanBuildFrom[Repr, (A1, B), That]. is found.

    that

    The iterable providing the second half of each result pair

    bf

    an implicit value of class CanBuildFrom which determines the result class That from the current representation type Repr and the new element type (A1, B).

    returns

    a new collection of type That containing pairs consisting of corresponding elements of this parallel iterable and that. The length of the returned collection is the minimum of the lengths of this parallel iterable and that.

    definition classes: ParIterableLikeIterableLike
  166. def zipAll [B] ( that : Iterable[B] , thisElem : T , thatElem : B ) : ParIterable[(T, B)]

    [use case] Returns a parallel iterable formed from this parallel iterable and another iterable collection by combining corresponding elements in pairs.

    [use case]

    Returns a parallel iterable formed from this parallel iterable and another iterable collection by combining corresponding elements in pairs. If one of the two collections is shorter than the other, placeholder elements are used to extend the shorter collection to the length of the longer.

    B

    the type of the second half of the returned pairs

    that

    The iterable providing the second half of each result pair

    thisElem

    the element to be used to fill up the result if this parallel iterable is shorter than that.

    thatElem

    the element to be used to fill up the result if that is shorter than this parallel iterable.

    returns

    a new parallel iterable containing pairs consisting of corresponding elements of this parallel iterable and that. The length of the returned collection is the maximum of the lengths of this parallel iterable and that. If this parallel iterable is shorter than that, thisElem values are used to pad the result. If that is shorter than this parallel iterable, thatElem values are used to pad the result.

    attributes: abstract
    definition classes: IterableLike
  167. def zipAll [S, U >: T, That] ( that : Iterable[S] , thisElem : U , thatElem : S )(implicit bf : CanBuildFrom[ParIterable[T], (U, S), That] ) : That

    Returns a parallel iterable formed from this parallel iterable and another iterable collection by combining corresponding elements in pairs.

    Returns a parallel iterable formed from this parallel iterable and another iterable collection by combining corresponding elements in pairs. If one of the two collections is shorter than the other, placeholder elements are used to extend the shorter collection to the length of the longer.

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    that

    the iterable providing the second half of each result pair

    thisElem

    the element to be used to fill up the result if this parallel iterable is shorter than that.

    thatElem

    the element to be used to fill up the result if that is shorter than this parallel iterable.

    returns

    a new collection of type That containing pairs consisting of corresponding elements of this parallel iterable and that. The length of the returned collection is the maximum of the lengths of this parallel iterable and that. If this parallel iterable is shorter than that, thisElem values are used to pad the result. If that is shorter than this parallel iterable, thatElem values are used to pad the result.

    definition classes: ParIterableLikeIterableLike
  168. def zipWithIndex : ParIterable[(T, Int)]

    [use case] Zips this parallel iterable with its indices.

    [use case]

    Zips this parallel iterable with its indices.

    returns

    A new parallel iterable containing pairs consisting of all elements of this parallel iterable paired with their index. Indices start at 0. @example List("a", "b", "c").zipWithIndex = List(("a", 0), ("b", 1), ("c", 2))

    attributes: abstract
    definition classes: IterableLike
  169. def zipWithIndex [U >: T, That] (implicit bf : CanBuildFrom[ParIterable[T], (U, Int), That] ) : That

    Zips this parallel iterable with its indices.

    Zips this parallel iterable with its indices.

    Note: might return different results for different runs, unless the underlying collection type is ordered.

    That

    the class of the returned collection. Where possible, That is the same class as the current collection class Repr, but this depends on the element type (A1, Int) being admissible for that class, which means that an implicit instance of type CanBuildFrom[Repr, (A1, Int), That]. is found.

    returns

    A new collection of type That containing pairs consisting of all elements of this parallel iterable paired with their index. Indices start at 0.

    definition classes: ParIterableLikeIterableLike

Inherited from ParIterable[T]

Inherited from ParIterableLike[T, ParIterable[T], Iterable[T]]

Inherited from Parallel

Inherited from CustomParallelizable[T, ParIterable[T]]

Inherited from GenericParTemplate[T, ParIterable]

Inherited from HasNewCombiner[T, ParIterable[T]]

Inherited from Iterable[T]

Inherited from Iterable[T]

Inherited from IterableLike[T, ParIterable[T]]

Inherited from Equals

Inherited from Traversable[T]

Inherited from Immutable

Inherited from Traversable[T]

Inherited from GenericTraversableTemplate[T, ParIterable]

Inherited from TraversableLike[T, ParIterable[T]]

Inherited from Parallelizable[T, ParIterable[T]]

Inherited from TraversableOnce[T]

Inherited from FilterMonadic[T, ParIterable[T]]

Inherited from HasNewBuilder[T, ParIterable[T]]

Inherited from AnyRef

Inherited from Any