close Warning: Can't synchronize with repository "(default)" (/var/svn/tolp does not appear to be a Subversion repository.). Look in the Trac log for more information.

Changes between Version 2 and Version 3 of VirtualMatrix


Ignore:
Timestamp:
Feb 27, 2009, 11:01:36 AM (16 years ago)
Author:
Víctor de Buen Remiro
Comment:

--

Legend:

Unmodified
Added
Removed
Modified
  • VirtualMatrix

    v2 v3  
    1212
    1313Las operaciones realizables con matrices virtuales dependen de cada subtipo lo cual complica algo su uso, pero como contrapartida se tiene acceso a métodos altamente especializados y eficaces.
     14
     15== BLAS&LAPACK ==
     16
     17    El motor de cálculo BLAS&LAPACK supone el paquete más consolidado de álgebra lineal y muchas de las operaciones del tipo Matrix ya lo usan, pero algunas características importantes no son accesibles por ese camino. Para ello se implementan subtipos especiales de VMatrix sobre los que se implementarán las funciones primitivas de BLAS&LAPACK con un interfaz lo más parecido al original que sea posible. Para sacar el máximo partido se debe contar con una implementación de BLAS optimizada para la máquina en que se vaya a usar.
     18
     19 * Column Major Dense: Es el tipo de datos básico de BLAS&LAPACK en el formato nativo de fortran en el que las celdas de cada columna son consecutivas, en contraposición al tipo Row Major considerado como nativo en C/C++ y usado en el tipo Matrix.
     20 * Triangular Compact: (Aún sin implemmentar) Se utiliza en algunos tratamiento de matrices triangulares y simétricas en las que sólo se tienen en cuenta la diagonal y las celdas por debajo de la misma, o bien las celdas por encima, ahorrando casi la mitad del espacio de memoria y de operaciones.
     21 * Banded Compact: (Aún sin implemmentar) En las matrices de bandas, de forma similar a las triangulares, sólo se tienen en cuenta las celdas de un rango de subdiagonales alrededor de la diagonal principal. Cuando el número de estas es reducido existen algoritmos muy eficientes que conjugan la especial estructura sparse con la eficacia de BLAS en el uso de la CPU.
     22
     23== CHOLMOD ==
     24
     25    Estos son los subtipos de matrices virtuales especializados para el motor de cálculo CHOLMOD para la resolución de sistemas lineales reales sparse y otros temas relacionados con la descomposición de Choleski a gran escala.
     26
     27 * Sparse: Es el tipo fundamental de matrices sparse de CHOLMOD y ofrece una amplia gama de operaciones implementadas de forma muy eficiente.
     28 * Factor: Es una especialización del anterior subtipo Sparse utilizada para almacenar la factorización de Choleski de una matriz Sparse de una forma especialemente eficaz para resolver los sistemas lineales asociados a dicha descomposición. Para realizar otras operaciones distintas de las específicas de este tipo se precisa transformarla primero al subtipo Sparse.
     29 * Dense: Coincide conceptual y físicamente con el Column Major Dense de BLAS y son completamente intercambiables pues se tratan internamente como uno sólo.
     30 * Triplet: Se ofrece tan sólo a efectos de almacenamiento externo e interfaz con otros sistemas. Se trata simplemente de ternas (i,j,x(i,j)) que vinculan el valor de cada celda al número de fila y columna al que corresponde, lo cual conjuga un ahorro importante de memoria con matrices suficientemente sparse con una gran facilidad de manejo, dado que la estructura interna de los subtipos Sparse y Factor es demasiado complicada para su manejo directo. No exiten operadores matriciales propiamente dichos para el trato directo de estos objetos, salvo los de conversión a otros formatos y los de extracción y ensamblaje de bloques.
     31