OjAlgo - OjAlgo

OjAlgo
Оригинальный автор (ы)Андерс Петерсон
Стабильный выпуск
Версия 44.0 / 27 сентября 2017 г. (2017-09-27)
Операционная системаКроссплатформенность
ТипБиблиотека
ЛицензияЛицензия MIT
Интернет сайтOjalgo.org

Ой! Алгоритмы или же ojAlgo, является Открытый исходный код Ява библиотека по математике,[1][2] линейная алгебра и оптимизация. Впервые он был выпущен в 2003 году.[3] и представляет собой 100% чистый исходный код Java и свободный от внешних зависимостей. Набор функций делает его особенно подходящим для использования в финансовой сфере.

Возможности

  • Линейная алгебра в Java
    • «высокопроизводительный» многопоточный полнофункциональный пакет линейной алгебры.
  • Оптимизация (математическое программирование), включая решатели LP, QP и MIP.
  • Код, связанный с финансами (безусловно, можно использовать и в других областях):
    • Обширный набор инструментов для работы с временными рядами - CalendarDateSeries, CoordinationSet и PrimitiveTimeSeries.
    • Случайные числа и стохастические процессы - даже многомерные - и способность управлять ими для выполнения таких задач, как моделирование методом Монте-Карло.
    • Коллекция классов, связанных с современной теорией портфеля - FinancePortfolio и его подклассы, реализации моделей Марковица и Блэка-Литтермана.
    • Возможность загрузки данных из Yahoo Finance и Google Finance.

Требуется Java 8 начиная с версии v38. Начиная с версии 44.0, специальный финансовый код был перемещен в собственный проект / модуль под названием ojAlgo-finance.[3]

Пример использования

Пример разложение по сингулярным числам:

SingularValue<Двойной> svd = SingularValueDecomposition.делать(matA);svd.вычислить(matA);MatrixStore<Двойной> U = svd.getQ1();MatrixStore<Двойной> S = svd.getD();MatrixStore<Двойной> V = svd.getQ2();

Пример умножения матриц:

PrimitiveDenseStore результат = ФАБРИКА.makeZero(matA.getRowDim(), matB.getColDim());результат.fillByMultiplying(matA, matB);

Рекомендации

  1. ^ Takaki, M .; Cavalcanti, D .; Gheyi, R .; Iyoda, J .; d’Amorim, M .; Пруденсио, Р. Б. (2010). «Рандомизированные решатели ограничений: сравнительное исследование». Биоинформатика. 6 (3): 243–253. Дои:10.1007 / s11334-010-0124-1.
  2. ^ Ванек, О .; Босанский, Б .; Jakob, M .; Печоучек, М. (2010). Транзитные зоны, патрулируемые мобильным противником. Симпозиум по вычислительному интеллекту и играм. С. 9–16.
  3. ^ а б "OJ! Страница проекта алгоритмов". Ой! Алгоритмы. Получено 2 июля, 2013.