mindspore.ops.Ormqr ==================== .. image:: https://mindspore-website.obs.cn-north-4.myhuaweicloud.com/website-images/master/resource/_static/logo_source.svg :target: https://gitee.com/mindspore/mindspore/blob/master/docs/api/api_python/ops/mindspore.ops.Ormqr.rst :alt: 查看源文件 .. py:class:: mindspore.ops.Ormqr(left=True, transpose=False) 计算一个普通矩阵与Householder矩阵的乘积。计算维度为(m, n)的矩阵C(由 `other` 给出)和一个矩阵Q的乘积, 其中Q由Householder反射系数(`x`, `tau`)表示,通常由 :func:`mindspore.ops.geqrf` 计算生成。 更多细节请参考 :func:`mindspore.ops.ormqr` 。 .. warning:: 这是一个实验性API,后续可能修改或删除。 参数: - **left** (bool, 可选) - 决定了矩阵乘积运算的顺序。如果 `left` 为 ``True`` ,计算顺序为op(Q) \* `other` ,否则,计算顺序为 `other` \* op(Q)。默认值: ``True`` 。 - **transpose** (bool, 可选) - 如果为 ``True`` ,对矩阵Q进行共轭转置变换,否则,不对矩阵Q进行共轭转置变换。默认值: ``False`` 。 输入: - **x** (Tensor) - shape :math:`(*, mn, k)`,mn的值取决于 `left` ,当 `left` 为 ``True`` 时, mn的值等于m,否则mn的值等于n。 `*` 表示Tensor在轴0上的长度为0或者大于0的batch维。 - **tau** (Tensor) - shape :math:`(*, min(mn, k))`,其中 `*` 表示Tensor在轴0上的长度为0或者大于0的batch维,其类型与 `x` 相同。 - **other** (Tensor) - shape :math:`(*, m, n)`,其中 `*` 表示Tensor在轴0上的长度为0或者大于0的batch维,其类型与 `x` 相同。 输出: - **y** (Tensor) - 输出Tensor,数据类型与shape与 `other` 一致。 异常: - **TypeError** - 如果 `x` , `tau` 或者 `other` 不是Tensor。 - **TypeError** - 如果 `x` , `tau` 和 `other` 的dtype不是float64、float32、complex64或者complex128。 - **ValueError** - 如果 `x` 或 `other` 的维度小于2D。 - **ValueError** - rank(`x`) - rank(`tau`) != 1。 - **ValueError** - tau.shape[:-1] != x.shape[:-2]。 - **ValueError** - other.shape[:-2] != x.shape[:-2]。 - **ValueError** - 当 `left` 为True时,other.shape[-2] < tau.shape[-1]。 - **ValueError** - 当 `left` 为True时,other.shape[-2] != x.shape[-2]。 - **ValueError** - 当 `left` 为False时,other.shape[-1] < tau.shape[-1]。 - **ValueError** - 当 `left` 为False时,other.shape[-1] != x.shape[-2]。