Znane podklasy pośrednie |
NdArray
podwójnych.
Metody publiczne
abstrakcyjna tablica DoubleNdArray | |
streszczenie NdArraySequence < DoubleNdArray > | elementy (int wymiarIdx) Zwraca sekwencję wszystkich elementów w danym wymiarze. |
abstrakcyjna tablica DoubleNdArray | uzyskać (długie... współrzędne) Zwraca element N-wymiarowy tej tablicy o podanych współrzędnych. |
abstrakcyjny dublet | getDouble (długie... współrzędne) Zwraca podwójną wartość skalara znalezionego przy podanych współrzędnych. |
streszczenie podwójne | getObject (długie... współrzędne) Zwraca wartość skalara znalezionego przy podanych współrzędnych. |
abstrakcyjna tablica DoubleNdArray | czytaj ( Bufor danych <Double> dst) |
abstrakcyjna tablica DoubleNdArray | czytaj ( DoubleDataBuffer dst) |
streszczenie NdArraySequence < DoubleNdArray > | skalary () Zwraca sekwencję wszystkich skalarów w tej tablicy. |
abstrakcyjna tablica DoubleNdArray | |
abstrakcyjna tablica DoubleNdArray | setDouble (podwójna wartość, długie... współrzędne) Przypisuje podwójną wartość skalara znalezionego przy podanych współrzędnych. |
abstrakcyjna tablica DoubleNdArray | setObject (podwójna wartość, długie... współrzędne) |
abstrakcyjna tablica DoubleNdArray | |
abstrakcyjna tablica DoubleNdArray | napisz ( Bufor danych <Double> src) |
abstrakcyjna tablica DoubleNdArray | napisz ( DoubleDataBuffer src) |
Metody dziedziczone
Metody publiczne
publiczne streszczenie NdArraySequence < DoubleNdArray > elementy (int DimensionIdx)
Zwraca sekwencję wszystkich elementów w danym wymiarze.
Logicznie rzecz biorąc, tablicę N-wymiarową można spłaszczyć w pojedynczym wektorze, gdzie skalary (n - 1)
-tego elementu poprzedzają skalary (n)
-tego elementu, co daje w sumie wartości size()
.
Na przykład, mając macierz nxm
na osiach [x, y]
, elementy są iterowane w następującej kolejności:
x 0 y 0 , x 0 y 1 , ..., x 0 y m-1 , x 1 y 0 , x 1 y 1 , ..., x n-1 y m-1
Zwróconą sekwencję można następnie iterować, aby odwiedzić każdy element, wywołując funkcję forEach(Consumer)
lub forEachIndexed(BiConsumer)
.
// Iterate matrix for initializing each of its vectors
matrixOfFloats.elements(0).forEach(v -> {
v.set(vector(1.0f, 2.0f, 3.0f));
);
// Iterate a vector for reading each of its scalar
vectorOfFloats.scalars().forEachIdx((coords, s) -> {
System.out.println("Value " + s.getFloat() + " found at " + coords);
});
}
Parametry
wymiarIdx | indeks wymiaru |
---|
Powroty
- sekwencja
NdArray
publiczne streszczenie DoubleNdArray get (długie... współrzędne)
Zwraca element N-wymiarowy tej tablicy o podanych współrzędnych.
Można pobrać elementy dowolnego wymiaru tej tablicy. Na przykład, jeśli liczba współrzędnych jest równa liczbie wymiarów tej tablicy, zwracana jest tablica o randze 0 (skalarna), której wartość można następnie uzyskać wywołując funkcję `array.getObject()`.
Wszelkie zmiany zastosowane do zwróconych elementów wpływają również na dane tej tablicy, ponieważ nie ma w tym przypadku żadnej kopii.
Należy zauważyć, że wywołanie tej metody jest równoważnym i skuteczniejszym sposobem podzielenia tej tablicy na pojedynczy skalar, tj. array.get(x, y, z)
jest równe array.slice(at(x), at(y), at(z))
Parametry
współrzędne | współrzędne elementu, do którego chcesz uzyskać dostęp, żadna nie zwróci tej tablicy |
---|
Powroty
- element o tym indeksie
publiczne streszczenie podwójne getDouble (długie... współrzędne)
Zwraca podwójną wartość skalara znalezionego przy podanych współrzędnych.
Aby uzyskać dostęp do elementu skalarnego, liczba podanych współrzędnych musi być równa liczbie wymiarów tej tablicy (tzn. jej rangi). Na przykład:
DoubleNdArray matrix = NdArrays.ofDoubles(shape(2, 2)); // matrix rank = 2
matrix.getDouble(0, 1); // succeeds, returns 0.0
matrix.getDouble(0); // throws IllegalRankException
DoubleNdArray scalar = matrix.get(0, 1); // scalar rank = 0
scalar.getDouble(); // succeeds, returns 0.0
Parametry
współrzędne | współrzędne skalara do rozwiązania |
---|
Powroty
- wartość tego skalara
Rzuca
Wyjątek IndexOutOfBounds | jeśli niektóre współrzędne znajdują się poza granicami odpowiednich wymiarów |
---|---|
Wyjątek IllegalRank | jeśli liczba współrzędnych nie jest wystarczająca, aby uzyskać dostęp do elementu skalarnego |
public streszczenie Podwójny getObject (długie... współrzędne)
Zwraca wartość skalara znalezionego przy podanych współrzędnych.
Aby uzyskać dostęp do elementu skalarnego, liczba podanych współrzędnych musi być równa liczbie wymiarów tej tablicy (tzn. jej rangi). Na przykład:
FloatNdArray matrix = NdArrays.ofFloats(shape(2, 2)); // matrix rank = 2
matrix.getObject(0, 1); // succeeds, returns 0.0f
matrix.getObject(0); // throws IllegalRankException
FloatNdArray scalar = matrix.get(0, 1); // scalar rank = 0
scalar.getObject(); // succeeds, returns 0.0f
floatArray.getFloat(0);
. Parametry
współrzędne | współrzędne skalara do rozwiązania |
---|
Powroty
- wartość tego skalara
publiczne streszczenie NdArraySequence < DoubleNdArray > skalary ()
Zwraca sekwencję wszystkich skalarów w tej tablicy.
Jest to równoważne wywołaniu elements(shape().numDimensions() - 1)
Powroty
- sekwencja
NdArray
public streszczenie DoubleNdArray setDouble (podwójna wartość, długie... współrzędne)
Przypisuje podwójną wartość skalara znalezionego przy podanych współrzędnych.
Aby uzyskać dostęp do elementu skalarnego, liczba podanych współrzędnych musi być równa liczbie wymiarów tej tablicy (tzn. jej rangi). Na przykład:
DoubleNdArray matrix = NdArrays.ofDoubles(shape(2, 2)); // matrix rank = 2
matrix.setDouble(10.0, 0, 1); // succeeds
matrix.setDouble(10.0, 0); // throws IllegalRankException
DoubleNdArray scalar = matrix.get(0, 1); // scalar rank = 0
scalar.setDouble(10.0); // succeeds
Parametry
wartość | wartość do przypisania |
---|---|
współrzędne | współrzędne skalara do przypisania |
Powroty
- ten układ
Rzuca
Wyjątek IndexOutOfBounds | jeśli niektóre współrzędne znajdują się poza granicami ich odpowiednich wymiarów |
---|---|
Wyjątek IllegalRank | jeśli liczba współrzędnych nie jest wystarczająca, aby uzyskać dostęp do elementu skalarnego |
publiczna abstrakcja DoubleNdArray plasterek ( Indeks... indeksy)
Tworzy wielowymiarowy widok (lub wycinek) tej tablicy, mapując jeden lub więcej wymiarów na dane selektory indeksu.
Plasterki umożliwiają przechodzenie przez N-wymiarową tablicę w dowolnej jej osi i/lub filtrowanie tylko interesujących ją elementów. Na przykład dla danej macierzy na osiach [x, y]
możliwe jest iterowanie elementów przy y=0
dla wszystkich x
.
Wszelkie zmiany zastosowane do zwróconego wycinka wpływają również na dane tej tablicy, ponieważ nie ma w tym przypadku żadnej kopii.
Przykład użycia:
FloatNdArray matrix3d = NdArrays.ofFloats(shape(3, 2, 4)); // with [x, y, z] axes
// Iterates elements on the x axis by preserving only the 3rd value on the z axis,
// (i.e. [x, y, 2])
matrix3d.slice(all(), all(), at(2)).elements(0).forEach(m -> {
assertEquals(shape(2), m); // y=2, z=0 (scalar)
);
// Creates a slice that contains only the last element of the y axis and elements with an
// odd `z` coordinate.
FloatNdArray slice = matrix3d.slice(all(), at(1), odd());
assertEquals(shape(3, 2), slice.shape()); // x=3, y=0 (scalar), z=2 (odd coordinates)
// Iterates backward the elements on the x axis
matrix3d.slice(flip()).elements(0).forEach(m -> {
assertEquals(shape(2, 4), m); // y=2, z=4
});
}
Parametry
indeksy | selektory indeksu według wymiarów, zaczynając od wymiaru 0 tej tablicy. |
---|
Powroty
- element wynikający z wyboru indeksu