Matrix Toolkit Java - Matrix Toolkit Java

Matrix Toolkit Java
Түпнұсқа автор (лар)Бьерн-Ове Хеймсунд
Бастапқы шығарылым2003; 17 жыл бұрын (2003)
Алдын ала қарау
0.9.14 / 22 қараша, 2011 жыл (2011-11-22)
Репозиторийgithub.com/ fommil/ matrix-toolkits-java
ЖазылғанJava
ТүріБағдарламалау интерфейсі (API)
ЛицензияLGPL

Matrix Toolkit Java (MTJ) - бұл ашық көзі Java бағдарламалық кітапхана сандық орындау үшін сызықтық алгебра. Кітапханада стандартты сызықтық алгебра операцияларының толық жиынтығы бар тығыз матрицалар негізінде BLAS және КЕШІК код. Ішінара жиынтығы сирек операциялар Үлгілер жобасы арқылы қамтамасыз етіледі. Кітапхананы таза Java кітапханасы ретінде іске қосуға немесе арқылы BLAS машиналық оңтайландырылған кодын пайдалануға конфигурациялауға болады Java жергілікті интерфейсі.

MTJ бастапқыда Бьорн-Ове Хеймсундпен жасалды, ол басқа міндеттемелерге байланысты шегінді. Жобаның веб-парағында «(жаңа техникалық қызмет көрсетушілер) бірінші кезекте кітапхананы күтіп ұстау және қателерді анықтаған кезде жоюмен айналысады. Болашақ шығарылымдардың жол жоспары жоқ» делінген.[1]

MTJ үшін бірнеше дәйексөзді ғылыми әдебиеттерден табуға болады, соның ішінде [2] оның LU алғышарттарын қолданады. MTJ өнімділігі басқа кітапханалармен салыстырылды, оларды Java Matrix Benchmark сайтында табуға болады.[3]

Мүмкіндіктер

Төменде жобаның веб-сайтында көрсетілген MTJ мүмкіндіктеріне шолу жасалған:

  • Төмен және құрылымды сирек матрицаларға арналған мәліметтер құрылымы келесі форматтарда:
    • Тығыз, бағаналы майор.
    • Бірнеше диагональды ғана сақтайтын матрицалық матрицалар.
    • Матрицалардың тек жартысын ғана сақтайтын матрицалар (үшбұрышты немесе симметриялы матрицалар үшін).
    • Триагональды және симметриялық тридиагональды матрицалар.
  • Симметриялы және үшбұрышты сақтау үшін мөлдір қолдау.
  • Осы форматтардағы құрылымдалмаған сирек матрицаларға арналған деректер құрылымдары:
    • Жолды немесе бағанды ​​қысылған сақтау (CRS / CCS).
    • Өсетін сирек векторларды қолдана отырып, икемді CRS / CCS.
    • Қысылған диагональды сақтау (CDS).
  • Тығыз және құрылымды сирек матрицалар BLAS және LAPACK үстінде салынған және оларға келесі ішкі операциялар кіреді:
    • Матрица / векторлық көбейту.
    • Матрицаны / матрицаны көбейту.
    • Жаңартуларды матрицалар немесе векторлар бойынша бағалау.
    • Тікелей матрицалық еріткіштер.
  • Құрылымданбаған сирек матрицалар құрылымдаумен бірдей операцияларды қолдайды, тек оларда тікелей еріткіштер жоқ. Алайда олардың матрицалық / векторлық көбейту әдістері итеративті еріткіштерде қолдану үшін оңтайландырылған.
  • Тығыз және құрылымды сирек матрицалардың матрицалық ыдырауы:
    • Л.У. және Холеский.
    • Симметриялы емес тығыз матрицалардың өзіндік мәні бойынша ыдырау.
    • Симметриялы емес тығыз матрицаларға арналған сингулярлық ыдырау.
    • Симметриялы матрицалар үшін өзіндік мәнді ыдырау (үшбұрышты, жолақты, оралған және тығыз).
    • Ортогональ матрица тығыз матрицалар үшін ыдырау (QR, RQ, LQ және QL).
  • Үлгілер жобасынан құрылымдалмаған сирек матрицалар үшін итеративті еріткіштер:
    • BiConjugate градиенттері.
    • BiConjugate градиенттері тұрақталды.
    • Градиенттерді біріктіру.
    • Квадраттық градиенттер квадрат түрінде.
    • Чебышевтің қайталануы.
    • Жалпыланған минималды қалдық (GMRES).
    • Итеративті нақтылау (Ричардсон әдісі).
    • Квазиминималды қалдық.
  • Алгебралық алғышарттарды таңдау:
    • Қиғаш алғышарттау.
    • Симметриялы бірінен соң бірі релаксация.
    • Аяқталмаған Холеский.
    • Толық емес LU.
    • Толық емес LU шекті мәнін пайдаланып толтырылған.
    • Тегістелген біріктіру арқылы алгебралық мультигрид.

Пайдалану мысалдары

Сингулярлық құндылықтың ыдырауының мысалы (SVD):

SVD svd = жаңа SVD(matA.numRows(),матА.numColumns());SVD с = svd.фактор(матА);DenseMatrix U = с.getU();DenseMatrix S = с.getS();DenseMatrix Vt = с.getVt();

Матрицаны көбейту мысалы:

DenseMatrix нәтиже = жаңа DenseMatrix(матА.numRows(),matB.numColumns());matA.көп(matB,нәтиже);

Сондай-ақ қараңыз

Әдебиеттер тізімі

  1. ^ «MTJ жобасының парағы». MTJ. Алынған 30 қараша, 2012.
  2. ^ Макмахан, Х.Б .; Гордон, Дж. (2005). «Марковтың шешім қабылдау үдерістеріндегі жылдам нақты жоспарлау» (PDF). Proc. Автоматтандырылған жоспарлау және жоспарлау жөніндегі 15-ші Халықаралық конференцияның (ICAPS-05).
  3. ^ «Java Matrix Benchmark». Алынған 6 желтоқсан, 2012.