0

我对 Oop 有点生疏了。我有以下代码。

classdef diag2by2
    properties
        a;
        b;
    end
    methods
        function obj = diag2by2(a, b)
            obj.a = a;
            obj.b = b;
        end
        function obj = plus(obj1, obj2)
            temp = [obj1.a,  0; 0 obj1.b]+ [obj2.a, 0; 0 obj2.b];
            obj.a = temp(1,1);
            obj.b = temp(2,2);
        end
        function obj = minus(obj1, obj2)
            temp = -1*obj2;
            obj = plus(obj1, temp);
        end
        function obj = mtimes(obj1, obj2)
            temp1 = [obj1.a,  0; 0 obj1.b];
            temp2 = [obj2.a, 0; 0 obj2.b];
            temp3 = temp1*temp2;
            obj.a = temp3(1,1);
            obj.b = temp3(2,2);
        end
        function r = matrix(obj)
            r = [obj.a,  0; 0 obj.b];

        end
    end
end

我正在尝试为 2by2 对角矩阵创建一个类。我在定义方法时遇到了麻烦。我有一个方法

    function r = matrix(obj)

这应该将我的对象转换为对角矩阵。但是当我尝试使用此方法时出现错误

a = diag2by2(1,2)

一个=

具有以下属性的 diag2by2:

a: 1
b: 2

a.matrix() 类 diag2by2 没有合适的方法、属性或字段矩阵。

有人可以帮我弄这个吗?

编辑:全班发布

4

1 回答 1

2

你已经matrix嵌套在里面mtimes

function obj = mtimes(obj1, obj2)
    temp1 = [obj1.a,  0; 0 obj1.b];
    temp2 = [obj2.a, 0; 0 obj2.b];
    temp3 = temp1*temp2;
    obj.a = temp3(1,1);
    obj.b = temp3(2,2);
function r = matrix(obj)
    r = [obj.a,  0; 0 obj.b];
end
end

编辑:你刚刚修好了吗?您的帖子不再像上面那样。

于 2013-10-04T19:49:47.087 回答