3

我在使用 JavaScript 中的矩阵乘法代码时遇到问题。如果我使用以下两个矩阵运行以下函数:

var m1 = [ [ 1, 0, 0 ],
  [ 0, 1, 0 ],
  [ 1, 1, 0 ],
  [ 0, 0, 1 ],
  [ 1, 0, 1 ],
  [ 0, 1, 1 ],
  [ 1, 1, 1 ] ];

var m2 = [ [ '0', '1', '1', '0', '0', '1', '1' ] ];

var matrixMult = function (m1, m2) {
    console.log(m1);
    console.log(m2);
    console.log("m1 length: %d, m2[0].length: %d", m1.length, m2[0].length);
    if (m1.length != m2[0].length) {
            console.error("Incompatible matrix dimensions for multiplication.");
            return false;
    }

    var result = [];

    for (var i = 0; i < m1[0].length; i++) {
            result[i] = [];
            for (var j = 0; j < m2.length; j++) {
                    var sum = 0;
                    for (var k = 0; k < m1.length; k++) {
                            sum += m1[i][k] * m2[k][j];
                    }
                    result[i][j] = sum;
            }
    }
    return result;
}

我收到此错误:

/path/to/file.js:58
                sum += m1[i][k] * m2[k][j];
                                       ^
TypeError: Cannot read property '0' of undefined
    at matrixMult (...)

怎么了?问题可能m2.length只是1吗?

4

1 回答 1

8

只有一个m2[0],但你的内for循环从0to运行m1.length,它大于0. 因此,当它尝试访问m2[1]它时会引发错误。

也通过以下矩阵乘法的定义

仅当左矩阵的列数与右矩阵的行数相同时,才定义两个矩阵的乘法。

(来源:维基百科

您不能将样本矩阵相乘,因为m1它有 3 列,但m2只有一行。

编辑

现在我正确理解了你的问题,我写了一个小函数可以帮助你:

function multiplyMatrix(m1, m2) {
    var result = [];
    for(var j = 0; j < m2.length; j++) {
        result[j] = [];
        for(var k = 0; k < m1[0].length; k++) {
            var sum = 0;
            for(var i = 0; i < m1.length; i++) {
                sum += m1[i][k] * m2[j][i];
            }
            result[j].push(sum);
        }
    }
    return result;
}

multiplyMatrix(m1, m2);

// => [ [2, 4, 2] ]
于 2013-02-13T09:48:11.257 回答