
fj.data.vector.V6 Maven / Gradle / Ivy
package fj.data.vector;
import fj.*;
import static fj.Function.curry;
import static fj.P.p2;
import fj.data.Array;
import fj.data.NonEmptyList;
import fj.data.Stream;
import java.util.Iterator;
/**
* A vector-6.
*/
public final class V6 implements Iterable {
private final V5 tail;
private final P1 head;
private V6(final P1 head, final V5 tail) {
this.head = head;
this.tail = tail;
}
@Override
public final boolean equals(Object other) {
return Equal.equals0(V6.class, this, other, () -> Equal.v6Equal(Equal.anyEqual()));
}
@Override
public final int hashCode() {
return Hash.v6Hash(Hash.anyHash()).hash(this);
}
/**
* Creates a vector-6 from a homogeneous product-6.
*
* @param p The product-6 from which to create a vector.
* @return A new vector-6.
*/
public static V6 p(final P6 p) {
return new V6<>(P.lazy(p::_1),
V5.p(new P5() {
public A _1() {
return p._2();
}
public A _2() {
return p._3();
}
public A _3() {
return p._4();
}
public A _4() {
return p._5();
}
public A _5() {
return p._6();
}
}));
}
/**
* Creates a vector-6 from a head and a tail.
*
* @param head The value to put as the first element of the vector.
* @param tail The vector representing all but the first element of the new vector.
* @return The new vector.
*/
public static V6 cons(final P1 head, final V5 tail) {
return new V6<>(head, tail);
}
/**
* Returns the first element of this vector.
*
* @return the first element of this vector.
*/
public A _1() {
return head._1();
}
/**
* Returns the second element of this vector.
*
* @return the second element of this vector.
*/
public A _2() {
return tail._1();
}
/**
* Returns the third element of this vector.
*
* @return the third element of this vector.
*/
public A _3() {
return tail._2();
}
/**
* Returns the fourth element of this vector.
*
* @return the fourth element of this vector.
*/
public A _4() {
return tail._3();
}
/**
* Returns the fifth element of this vector.
*
* @return the fifth element of this vector.
*/
public A _5() {
return tail._4();
}
/**
* Returns the sixth element of this vector.
*
* @return the sixth element of this vector.
*/
public A _6() {
return tail._5();
}
/**
* Returns all but the first element of this vector, as a vector-5.
*
* @return all but the first element of this vector, as a vector-5.
*/
public V5 tail() {
return tail;
}
/**
* Returns the first element of this vector, as a product-1.
*
* @return the first element of this vector, as a product-1.
*/
public P1 head() {
return head;
}
/**
* Returns an iterator for the elements of this vector.
*
* @return an iterator for the elements of this vector.
*/
public Iterator iterator() {
return toStream().iterator();
}
/**
* Returns a homogeneous product-6 equivalent to this vector.
*
* @return a homogeneous product-6 equivalent to this vector.
*/
public P6 p() {
return new P6() {
public A _1() {
return V6.this._1();
}
public A _2() {
return V6.this._2();
}
public A _3() {
return V6.this._3();
}
public A _4() {
return V6.this._4();
}
public A _5() {
return V6.this._5();
}
public A _6() {
return V6.this._6();
}
};
}
/**
* Returns a nonempty list with the elements of this vector.
*
* @return a nonempty list with the elements of this vector.
*/
public NonEmptyList toNonEmptyList() {
return NonEmptyList.nel(_1(), tail.toNonEmptyList().toList());
}
/**
* Returns a stream of the elements of this vector.
*
* @return a stream of the elements of this vector.
*/
public Stream toStream() {
return Stream.cons(head._1(), tail::toStream);
}
/**
* Returns an array with the elements of this vector.
*
* @return an array with the elements of this vector.
*/
@SuppressWarnings("unchecked")
public Array toArray() {
return Array.array(_1(), _2(), _3(), _4(), _5(), _6());
}
/**
* Maps the given function across this vector.
*
* @param f The function to map across this vector.
* @return A new vector after the given function has been applied to each element.
*/
public V6 map(final F f) {
return new V6<>(head.map(f), tail.map(f));
}
/**
* Performs function application within a vector (applicative functor pattern).
*
* @param vf The vector of functions to apply.
* @return A new vector after zipping the given vector of functions over this vector.
*/
public V6 apply(final V6> vf) {
return new V6<>(head.apply(vf.head()), tail.apply(vf.tail()));
}
/**
* Zips this vector with the given vector using the given function to produce a new vector.
*
* @param bs The vector to zip this vector with.
* @param f The function to zip this vector and the given vector with.
* @return A new vector with the results of the function.
*/
public V6 zipWith(final F> f, final V6 bs) {
return bs.apply(map(f));
}
/**
* Zips this vector with the given vector to produce a vector of pairs.
*
* @param bs The vector to zip this vector with.
* @return A new vector with a length the same as the shortest of this vector and the given
* vector.
*/
public V6> zip(final V6 bs) {
final F>> __2 = p2();
return zipWith(__2, bs);
}
/**
* Zips this vector with the given vector to produce a vector of vectors.
*
* @param bs The vector to zip this vector with.
* @return A new vector of vectors.
*/
public V6> vzip(final V6 bs) {
final F2> __2 = V.v2();
return zipWith(curry(__2), bs);
}
/**
* Returns a function that transforms a vector-6 to a stream of its elements.
*
* @return a function that transforms a vector-6 to a stream of its elements.
*/
public static F, Stream> toStream_() {
return V6::toStream;
}
/**
* Returns a function that transforms a vector-6 to the equivalent product-6.
*
* @return a function that transforms a vector-6 to the equivalent product-6.
*/
public static F, P6> p_() {
return V6::p;
}
/**
* A first-class function to get the first element of a vector.
*
* @return a function that gets the first element of a given vector.
*/
public static F, A> __1() {
return V6::_1;
}
/**
* A first-class function to get the second element of a vector.
*
* @return a function that gets the second element of a given vector.
*/
public static F, A> __2() {
return V6::_2;
}
/**
* A first-class function to get the third element of a vector.
*
* @return a function that gets the third element of a given vector.
*/
public static F, A> __3() {
return V6::_3;
}
/**
* A first-class function to get the fourth element of a vector.
*
* @return a function that gets the fourth element of a given vector.
*/
public static F, A> __4() {
return V6::_4;
}
/**
* A first-class function to get the fifth element of a vector.
*
* @return a function that gets the fifth element of a given vector.
*/
public static F, A> __5() {
return V6::_5;
}
/**
* A first-class function to get the sixth element of a vector.
*
* @return a function that gets the sixth element of a given vector.
*/
public static F, A> __6() {
return V6::_6;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy