زیر کلاس های غیر مستقیم شناخته شده AbstractDenseNdArray <T, U گسترش NdArray <T>>, AbstractNdArray <T, U گسترش NdArray <T>>, BooleanDenseNdArray , BooleanNdArray , ByteDenseNdArray , ByteNdArray , DenseNdArray , DoubleNdArray , NdArray <Nd> ray ، FloatNdArray ، IntDenseNdArray ، IntNdArray ، LongDenseNdArray ، LongNdArray و 11 نفر دیگر. |
ساختار داده ای از ابعاد N.
رابط «NdArray» یک انتزاع بین ذخیره فیزیکی یک رکورد داده، که می تواند خطی یا قطعه بندی شده باشد، و نمایش منطقی آن ایجاد می کند. به طور کلی، آنها عملکرد بهتری نسبت به آرایه های چند بعدی استاندارد در جاوا با نگاشت مستقیم بخش های داده خطی در حافظه دارند.
مانند DataBuffer
، نمونه های NdArray
از نمایه سازی 64 بیتی پشتیبانی می کنند تا بتوان از آنها برای نقشه برداری رکوردهای داده بسیار بزرگ استفاده کرد. آنها همچنین از مختصات خاصی پشتیبانی می کنند که به آنها اجازه می دهد مقادیر آنها را در هر جهتی عبور دهند یا فقط زیر مجموعه ای از آنها را انتخاب کنند.
مثال استفاده:
// Creates a 2x3x2 matrix (of rank 3)
FloatNdArray matrix3d = NdArrays.ofFloats(shape(2, 3, 2));
// Initialize sub-matrices data with vectors
matrix.set(NdArrays.vectorOf(1.0f, 2.0f), 0, 0)
.set(NdArrays.vectorOf(3.0f, 4.0f), 0, 1)
.set(NdArrays.vectorOf(5.0f, 6.0f), 0, 2)
.set(NdArrays.vectorOf(7.0f, 8.0f), 1, 0)
.set(NdArrays.vectorOf(9.0f, 10.0f), 1, 1)
.set(NdArrays.vectorOf(11.0f, 12.0f), 1, 2);
// Access the second 3x2 matrix (of rank 2)
FloatNdArray matrix = matrix3d.get(1);
// Access directly the float value at (1, 0) from the second matrix
assertEquals(9.0f, matrix.getFloat(1, 0));
روش های عمومی
انتزاعی NdArray <T> | |
انتزاعی NdArraySequence <? NdArray <T>> را گسترش می دهد | عناصر (int dimensionIdx) دنباله ای از همه عناصر را در یک بعد معین برمی گرداند. |
بولی انتزاعی | برابر است (object obj) برابری بین آرایه های n بعدی را بررسی می کند. |
انتزاعی NdArray <T> | دریافت (طولانی... مختصات) عنصر N بعدی این آرایه را در مختصات داده شده برمی گرداند. |
چکیده تی | getObject (مختصات طولانی...) مقدار اسکالر موجود در مختصات داده شده را برمیگرداند. |
انتزاعی NdArray <T> | |
انتزاعی NdArraySequence <? NdArray <T>> را گسترش می دهد | اسکالر () دنباله ای از تمام اسکالرها در این آرایه را برمی گرداند. |
انتزاعی NdArray <T> | |
انتزاعی NdArray <T> | setObject (مقدار T، مختصات طولانی...) مقدار اسکالر موجود در مختصات داده شده را تعیین می کند. |
انتزاعی NdArray <T> | |
انتزاعی NdArray <T> |
روش های ارثی
روش های عمومی
چکیده عمومی NdArray <T> copyTo ( NdArray <T> dst)
محتوای این آرایه را در آرایه مقصد کپی کنید.
shape()
آرایه مقصد باید با شکل این آرایه برابر باشد، در غیر این صورت استثنا ایجاد می شود. پس از کپی، محتوای هر دو آرایه را می توان به طور مستقل تغییر داد، بدون اینکه بر یکدیگر تأثیر بگذارند.
پارامترها
dst | آرایه برای دریافت یک کپی از محتوای این آرایه |
---|
برمی گرداند
- این آرایه
پرتاب می کند
IllegalArgumentException | اگر شکل dst با شکل این آرایه برابر نباشد |
---|
چکیده عمومی NdArraySequence <? عناصر NdArray <T>> را گسترش می دهد (int dimensionIdx)
دنباله ای از همه عناصر را در یک بعد معین برمی گرداند.
به طور منطقی، آرایه بعدی N را می توان در یک بردار واحد مسطح کرد، جایی که اسکالرهای عنصر (n - 1)
قبل از عنصر (n)
ام، برای کل مقادیر size()
می گیرند.
برای مثال، با توجه به یک ماتریس nxm
روی محورهای [x, y]
، عناصر به ترتیب زیر تکرار میشوند:
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
سپس میتوان دنباله برگشتی را برای بازدید از هر عنصر، با فراخوانی forEach(Consumer)
یا 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);
});
}
پارامترها
dimensionIdx | شاخص بعد |
---|
برمی گرداند
- یک دنباله
NdArray
پرتاب می کند
IllegalArgumentException | اگر dimensionIdx بزرگتر یا مساوی تعداد کل ابعاد این آرایه باشد |
---|
بولین انتزاعی عمومی برابر است (object obj)
برابری بین آرایه های n بعدی را بررسی می کند.
یک آرایه با شی دیگری برابر است اگر این شی NdArray
دیگری با همان شکل، نوع و عناصر برابر و به یک ترتیب باشند. به عنوان مثال:
IntNdArray array = NdArrays.ofInts(Shape.of(2, 2))
.set(NdArrays.vectorOf(1, 2), 0)
.set(NdArrays.vectorOf(3, 4), 1);
assertEquals(array, StdArrays.ndCopyOf(new int[][] { {1, 2
, {3, 4} })); // true
assertEquals(array, StdArrays.ndCopyOf(new Integer[][] { {1, 2}, {3, 4} })); // true, as Integers are equal to ints
assertNotEquals(array, NdArrays.vectorOf(1, 2, 3, 4)); // false, different shapes
assertNotEquals(array, StdArrays.ndCopyOf(new int[][] { {3, 4}, {1, 2} })); // false, different order
assertNotEquals(array, StdArrays.ndCopyOf(new long[][] { {1L, 2L}, {3L, 4L} })); // false, different types
}
توجه داشته باشید که محاسبات مورد نیاز برای تأیید برابری بین دو آرایه در برخی موارد میتواند گران باشد و بنابراین، توصیه میشود از این روش در مسیر بحرانی که عملکردها اهمیت دارند استفاده نکنید.
پارامترها
obj | شی برای مقایسه این آرایه با |
---|
برمی گرداند
- درست است اگر این آرایه برابر با شی ارائه شده باشد
انتزاع عمومی NdArray <T> دریافت (مختصات طولانی...)
عنصر N بعدی این آرایه را در مختصات داده شده برمی گرداند.
عناصر هر یک از ابعاد این آرایه قابل بازیابی هستند. به عنوان مثال، اگر تعداد مختصات برابر با تعداد ابعاد این آرایه باشد، یک آرایه رتبه-0 (اسکالر) برگردانده می شود که با فراخوانی «array.getObject()» مقدار آن را می توان به دست آورد.
هر تغییری که در عناصر برگشتی اعمال شود، داده های این آرایه را نیز تحت تأثیر قرار می دهد، زیرا هیچ کپی در کار نیست.
توجه داشته باشید که فراخوانی این روش روشی معادل و کارآمدتر برای برش این آرایه بر روی یک اسکالر است، یعنی array.get(x, y, z)
برابر است با array.slice(at(x), at(y), at(z))
پارامترها
مختصات | مختصات عنصر برای دسترسی، هیچ یک این آرایه را بر نمی گرداند |
---|
برمی گرداند
- عنصر موجود در این شاخص
پرتاب می کند
IndexOutOfBoundsException | اگر برخی از مختصات خارج از محدوده بعد مربوطه خود باشند |
---|
انتزاع عمومی T getObject (مختصات طولانی...)
مقدار اسکالر موجود در مختصات داده شده را برمیگرداند.
برای دسترسی به عنصر اسکالر، تعداد مختصات ارائه شده باید با تعداد ابعاد این آرایه (یعنی رتبه آن) برابر باشد. به عنوان مثال:
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);
. پارامترها
مختصات | مختصات اسکالر برای حل کردن |
---|
برمی گرداند
- ارزش آن اسکالر
پرتاب می کند
IndexOutOfBoundsException | اگر برخی از مختصات خارج از محدوده بعد مربوطه خود باشند |
---|---|
IllegalRankException | اگر تعداد مختصات برای دسترسی به یک عنصر اسکالر کافی نباشد |
چکیده عمومی NdArray <T> خوانده شده ( DataBuffer <T> dst)
محتوای این آرایه N بعدی را در بافر مقصد بخوانید.
اندازه بافر باید برابر یا بزرگتر از size()
این آرایه باشد، در غیر این صورت یک استثنا ایجاد می شود. پس از کپی، محتوای بافر و آرایه را می توان به طور مستقل تغییر داد، بدون اینکه بر یکدیگر تأثیر بگذارند.
پارامترها
dst | بافر مقصد |
---|
برمی گرداند
- این آرایه
پرتاب می کند
BufferOverflowException | اگر بافر نتواند محتوای این آرایه را نگه دارد |
---|
همچنین ببینید
چکیده عمومی NdArraySequence <? اسکالرهای NdArray <T>> را گسترش می دهد ()
دنباله ای از تمام اسکالرها در این آرایه را برمی گرداند.
این معادل فراخوانی elements(shape().numDimensions() - 1)
برمی گرداند
- یک دنباله
NdArray
مجموعه انتزاعی عمومی NdArray <T> ( NdArray <T> src، long... مختصات)
مقدار عنصر N بعدی موجود در مختصات داده شده را تعیین می کند.
تعداد مختصات ارائه شده می تواند بین 0 و رتبه - 1 باشد. به عنوان مثال:
FloatNdArray matrix = NdArrays.ofFloats(shape(2, 2)); // matrix rank = 2
matrix.set(vector(10.0f, 20.0f), 0); // success
matrix.set(scalar(10.0f), 1, 0); // success
پارامترها
src | آرایه ای از مقادیر برای تخصیص |
---|---|
مختصات | مختصات عنصر برای تخصیص |
برمی گرداند
- این آرایه
پرتاب می کند
IndexOutOfBoundsException | اگر برخی از مختصات خارج از محدوده بعد مربوطه خود باشند |
---|
انتزاع عمومی NdArray <T> setObject (مقدار T، طولانی... مختصات)
مقدار اسکالر موجود در مختصات داده شده را تعیین می کند.
برای دسترسی به عنصر اسکالر، تعداد مختصات ارائه شده باید با تعداد ابعاد این آرایه (یعنی رتبه آن) برابر باشد. به عنوان مثال:
FloatNdArray matrix = NdArrays.ofFloats(shape(2, 2)); // matrix rank = 2
matrix.setObject(10.0f, 0, 1); // succeeds
matrix.setObject(10.0f, 0); // throws IllegalRankException
FloatNdArray scalar = matrix.get(0, 1); // scalar rank = 0
scalar.setObject(10.0f); // succeeds
توجه: اگر این آرایه مقادیری از نوع اولیه را ذخیره می کند، استفاده از روش تخصصی را در زیر کلاس برای آن نوع ترجیح دهید. برای مثال floatArray.setFloat(10.0f, 0);
پارامترها
ارزش | مقدار برای تخصیص |
---|---|
مختصات | مختصات اسکالر برای تخصیص |
برمی گرداند
- این آرایه
پرتاب می کند
IndexOutOfBoundsException | اگر برخی از مختصات خارج از محدوده بعد مربوطه خود باشند |
---|---|
IllegalRankException | اگر تعداد مختصات برای دسترسی به یک عنصر اسکالر کافی نباشد |
انتزاع عمومی NdArray <T> برش ( شاخص ... شاخص)
یک نمای چند بعدی (یا برش) از این آرایه با نگاشت یک یا چند بعد به انتخابگرهای شاخص داده شده ایجاد می کند.
برش ها امکان عبور از یک آرایه N-بعدی را در هر یک از محورهای آن و/یا فیلتر کردن فقط عناصر مورد نظر را فراهم می کنند. به عنوان مثال، برای یک ماتریس معین روی محورهای [x, y]
، میتوان عناصر را با y=0
برای همه x
تکرار کرد.
هر گونه تغییر اعمال شده در برش برگشتی بر روی داده های این آرایه نیز تأثیر می گذارد، زیرا هیچ کپی در کار نیست.
مثال استفاده:
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
});
}
پارامترها
شاخص ها | انتخابگرهای شاخص در هر ابعاد، از بعد 0 این آرایه شروع می شود. |
---|
برمی گرداند
- عنصر حاصل از انتخاب شاخص
پرتاب می کند
IndexOutOfBoundsException | اگر برخی از مختصات خارج از محدوده بعد مربوطه خود باشند |
---|
انتزاع عمومی NdArray <T> نوشتن ( DataBuffer <T> src)
محتوای این آرایه N بعدی را از بافر منبع بنویسید.
اندازه بافر باید برابر یا بزرگتر از size()
این آرایه باشد، در غیر این صورت یک استثنا ایجاد می شود. پس از کپی، محتوای بافر و آرایه را می توان به طور مستقل تغییر داد، بدون اینکه بر یکدیگر تأثیر بگذارند.
پارامترها
src | بافر منبع |
---|
برمی گرداند
- این آرایه
پرتاب می کند
BufferUnderflowException | اگر بافر اطلاعات کافی برای نوشتن در این آرایه نداشته باشد |
---|