Gael Guennebaud
|
5861cfb55e
|
Remove unused GenericSparseBlockInnerIteratorImpl code.
|
2015-04-01 22:29:29 +02:00 |
|
Gael Guennebaud
|
3105986e71
|
bug #875: remove broken SparseMatrixBase::nonZeros and introduce a nonZerosEstimate() method to sparse evaluators for internal uses.
Factorize some code in SparseCompressedBase.
|
2015-04-01 22:27:34 +02:00 |
|
Gael Guennebaud
|
39dcd01b0a
|
bug #973: enable alignment of multiples of half-packet size (e.g., Vector6d with AVX)
|
2015-04-01 13:55:09 +02:00 |
|
Gael Guennebaud
|
8481dc21ea
|
bug #986: add support for coefficient-based product with 0 depth.
|
2015-04-01 13:15:23 +02:00 |
|
Gael Guennebaud
|
79b4e6acaf
|
Fix bug #987: wrong alignement guess in diagonal product.
|
2015-03-31 23:35:12 +02:00 |
|
Gael Guennebaud
|
3c38589984
|
Remove most of the dynamic memory allocations that occured in D&C SVD. Still remains the calls to JacobiSVD and UpperBidiagonalization.
|
2015-03-31 22:54:47 +02:00 |
|
Gael Guennebaud
|
8313fb7df7
|
Add row/column-wise reverseInPlace feature.
|
2015-03-31 21:35:53 +02:00 |
|
Gael Guennebaud
|
dfb674a25e
|
Make reverseInPlace really work in-place.
|
2015-03-31 20:17:10 +02:00 |
|
Gael Guennebaud
|
20d030f207
|
Fix vectorization of swap for non trivial expressions
|
2015-03-31 20:16:02 +02:00 |
|
Benoit Jacob
|
73cdeae1d3
|
Only use blocking sizes LUTs for single-thread products for now
|
2015-03-31 11:17:23 -04:00 |
|
Benoit Jacob
|
0cbd5ae3cb
|
Correctly detect Android with ndk_build
|
2015-03-31 11:17:21 -04:00 |
|
Gael Guennebaud
|
ae01c05e18
|
Fix computeProductBlockingSizes with m==0, and add respective unit test.
|
2015-03-31 15:19:57 +02:00 |
|
Gael Guennebaud
|
bd76d837e6
|
Fix sign of SuperLU::determinant
|
2015-03-31 14:57:32 +02:00 |
|
Gael Guennebaud
|
35d3053d55
|
Fix regression introduced in 3b169d792d
|
2015-03-31 09:23:53 +02:00 |
|
Christoph Hertzberg
|
3b169d792d
|
Suppress unused variable warning
|
2015-03-31 00:49:08 +02:00 |
|
Christoph Hertzberg
|
1efae98fee
|
bug #985: RealQZ failed when either matrix had zero rows or columns (report and patch by Ben Goodrich)
Also added a regression test
|
2015-03-30 23:56:20 +02:00 |
|
Christoph Hertzberg
|
58af8bf90c
|
bug #982: Make sure numext::maxi and numext::mini are called correctly, in case Scalar expressions return expression templates.
|
2015-03-30 16:47:22 +02:00 |
|
Gael Guennebaud
|
2adbf6b8ca
|
fix stupid warning with old GCC
|
2015-03-28 22:34:54 +01:00 |
|
Gael Guennebaud
|
41e20248f8
|
merge
|
2015-03-28 14:43:35 +01:00 |
|
Christoph Hertzberg
|
09a5361d1b
|
bug #983: Pass Vector3 by const reference and not by value
|
2015-03-28 12:36:24 +01:00 |
|
Gael Guennebaud
|
eb7e4c2b9c
|
Pass Vector3 type by reference
|
2015-03-27 12:11:24 +01:00 |
|
Gael Guennebaud
|
79cb875249
|
merge
|
2015-03-27 10:56:04 +01:00 |
|
Gael Guennebaud
|
1b8cc9af43
|
Slight numerical stability improvement in 2x2 svd
|
2015-03-27 10:55:00 +01:00 |
|
Gael Guennebaud
|
3d59ae0203
|
Fix hypot(0,0).
|
2015-03-27 09:59:24 +01:00 |
|
Benoit Steiner
|
abdbe8562e
|
Fixed the CUDA packet primitives
|
2015-03-24 10:45:46 -07:00 |
|
Gael Guennebaud
|
29eaa2b0f1
|
Make MatrixBase::is* methods aware of nested_eval.
|
2015-03-24 13:42:42 +01:00 |
|
Gael Guennebaud
|
d27968eb7e
|
D&C SVD: directly falls back to JacobiSVD for very small problems (by-pass upper-bidiagonalization)
|
2015-03-24 13:38:07 +01:00 |
|
Gael Guennebaud
|
4472f3e578
|
Avoid SVD: consider denormalized small numbers as zero when computing the rank of the matrix
|
2015-03-23 09:40:21 +01:00 |
|
Gael Guennebaud
|
4e2b18d909
|
Update approx. minimum ordering method to push and keep structural empty diagonal elements to the bottom-right part of the matrix
|
2015-03-20 16:33:48 +01:00 |
|
Gael Guennebaud
|
d6b2f300db
|
Fix MSVC compilation: aligned type must be passed by reference
|
2015-03-19 17:28:32 +01:00 |
|
Gael Guennebaud
|
61c45d7cfd
|
Fix comparison warning
|
2015-03-19 17:13:22 +01:00 |
|
Gael Guennebaud
|
f329d0908a
|
Improve random number generation for integer and add unit test
|
2015-03-19 15:10:36 +01:00 |
|
Benoit Jacob
|
dc04f12967
|
use unsigned short instead of uint16_t which doesn't exist in c++98
|
2015-03-17 10:31:45 -04:00 |
|
Benoit Jacob
|
364cfd529d
|
Similar to cset 3589a9c115
, also in 2px4 kernel: actual_panel_rows computation should always be resilient to parameters not consistent with the known L1 cache size, see comment
|
2015-03-16 16:28:44 -04:00 |
|
Benoit Jacob
|
577056aa94
|
Include stdint.h. Not going for cstdint because it is a C++11 addition. Needed for uint16_t at least, in lookup-table code.
|
2015-03-16 16:21:50 -04:00 |
|
Benoit Jacob
|
eb6929cb19
|
fix bug in maxsize calculation, which would cause products of size > 2048 to address the lookup table out of bounds
|
2015-03-16 16:15:47 -04:00 |
|
Benoit Jacob
|
35c3a8bb84
|
Update Nexus 5 lookup table from combining now 2 runs of the benchmark, using the analyze-blocking-sizes partition tool. Gives better worst-case performance.
|
2015-03-16 11:05:51 -04:00 |
|
Benoit Jacob
|
e274607d7f
|
fix compilation with GCC 4.8
|
2015-03-16 10:48:27 -04:00 |
|
Benoit Jacob
|
151b8b95c6
|
Fix bug in case where EIGEN_TEST_SPECIFIC_BLOCKING_SIZE is defined but false
|
2015-03-15 19:10:51 -04:00 |
|
Benoit Jacob
|
02babb9c0f
|
Provide a empirical lookup table for blocking sizes measured on a Nexus 5. Only for float, only for Android on ARM 32bit for now.
|
2015-03-15 18:13:12 -04:00 |
|
Benoit Jacob
|
3589a9c115
|
actual_panel_rows computation should always be resilient to parameters not consistent with the known L1 cache size, see comment
|
2015-03-15 18:12:18 -04:00 |
|
Benoit Jacob
|
1dd3d89818
|
Fix a unused-var warning
|
2015-03-15 18:07:19 -04:00 |
|
Benoit Jacob
|
e56aabf205
|
Refactor computeProductBlockingSizes to make room for the possibility of using lookup tables
|
2015-03-15 18:05:12 -04:00 |
|
Benoit Jacob
|
488c15615a
|
organize a little our default cache sizes, and use a saner default L1 outside of x86 (10% faster on Nexus 5)
|
2015-03-13 14:51:26 -07:00 |
|
Gael Guennebaud
|
1330f8bbd1
|
bug #973, improve AVX support by enabling vectorization of Vector4i-like types, and enforcing alignement of Vector4f/Vector2d-like types to preserve compatibility with SSE and future Eigen versions that will vectorize them with AVX enabled.
|
2015-03-13 21:15:50 +01:00 |
|
Gael Guennebaud
|
d99ab35f9e
|
Fix internal::random(x,y) for integer types. The previous implementation could return y+1. The new implementation uses rejection sampling to get an unbiased behabior.
|
2015-03-13 21:12:46 +01:00 |
|
Gael Guennebaud
|
8580eb6808
|
bug #949: add static assertion for incompatible scalar types in dense end-user decompositions.
|
2015-03-13 21:06:20 +01:00 |
|
Gael Guennebaud
|
a9df28c95b
|
SparseMatrix::insert: switch to a fully uncompressed mode if sequential insertion is not possible (otherwise an arbitrary large amount of memory was preallocated in some cases)
|
2015-03-13 21:00:21 +01:00 |
|
Gael Guennebaud
|
5ffe29cb9f
|
Bound pre-allocation to the maximal size representable by StorageIndex and throw bad_alloc if that's not possible.
|
2015-03-13 20:57:33 +01:00 |
|
Gael Guennebaud
|
2f6f8bf31c
|
Add missing coeff/coeffRef members to Block<sparse>, and extend unit tests.
|
2015-03-13 16:24:40 +01:00 |
|