Перегрузка операторов

Почему операторы перегрузки

Путем реализации операторов, которые подходят для класса, можно интегрировать объекты класса в MATLAB® язык. Например, объекты, которые содержат числовые данные, могут задать арифметические операции как +, *, - так, чтобы можно было использовать эти объекты в арифметических выражениях. Путем реализации операторов отношения можно использовать объекты в условных операторах, как switch и if операторы.

Как задать операторы

Можно реализовать операторы MATLAB, чтобы работать с объектами класса. Чтобы реализовать операторы, задайте связанные методы класса.

Каждый оператор имеет присоединенную функцию (например, +, оператор имеет связанный plus.m функция. Можно реализовать любой оператор путем создания метода класса с соответствующим именем. Этот метод может выполнить любые шаги, подходят для реализовываемой операции.

Для списка операторов и имен присоединенной функции, смотрите Операторы MATLAB и Присоединенные функции.

Приоритет объекта в операциях

Пользовательские классы имеют более высокий приоритет, чем встроенные классы. Например, предположите q объект класса double и p пользовательский класс. Оба из этих выражений генерируют вызов plus метод в пользователе - задает класс, если это существует:

q + p 
p + q

Может ли этот метод добавить объекты класса double и пользовательский класс зависит от того, как вы реализуете метод.

Когда p и q объекты различных классов, MATLAB применяет правила приоритета определить который метод использовать.

Приоритет объекта в Вызове метода предоставляет информацию о том, как MATLAB определяет который метод вызвать.

Приоритет операторов

Перегруженные операторы сохраняют исходный приоритет MATLAB для оператора. Для получения информации о приоритете оператора см. Приоритет операторов.

Демонстрационная реализация - объекты Аддэйбла

Adder класс реализует сложение для объектов этого класса путем определения plus метод. Adder задает сложение объектов как сложение NumericData значения свойств. plus метод создает и возвращает Adder возразите чей NumericData значение свойства является результатом сложения.

Adder класс также реализует меньше, чем оператор (<) путем определения lt метод. lt метод возвращает логическое значение после сравнения значений в каждом объекте NumericData свойство.

classdef Adder
   properties
      NumericData
   end
   methods
      function obj = Adder(val)
         obj.NumericData = val;
      end
      function r = plus(obj1,obj2)
         a = double(obj1);
         b = double(obj2);
         r = Adder(a + b);
      end
      function d = double(obj)
         d = obj.NumericData;
      end
      function tf = lt(obj1,obj2)
         if obj1.NumericData < obj2.NumericData
            tf = true;
         else
            tf = false;
         end
      end
   end
end

Использование двойного конвертера позволяет вам добавить числовые значения в Adder объекты и выполнять сложение на объектах класса.

a = Adder(1:10)
a = 

  Adder with properties:

    NumericData: [1 2 3 4 5 6 7 8 9 10]

Добавьте два объекта:

a + a
ans = 

  Adder with properties:

    NumericData: [2 4 6 8 10 12 14 16 18 20]

Добавьте объект с любым значением, которое может быть брошено, чтобы удвоиться:

b = uint8(255) + a
b = 

  Adder with properties:

    NumericData: [256 257 258 259 260 261 262 263 264 265]

Сравните возражает a и b использование < оператор:

a < b
ans =

     1

Убедитесь, что ваш класс обеспечивает любую проверку ошибок, требуемую реализовывать ваш проект класса.

Операторы MATLAB и присоединенные функции

В следующей таблице перечислены имена функций для операторов MATLAB. Реализация операторов, чтобы работать с массивами (скалярное расширение, векторизованные арифметические операции, и так далее), может также потребовать индексации изменения и конкатенации. Используйте ссылки в этой таблице, чтобы найти определенную информацию о каждой функции.

Операция

Метод, чтобы задать

Описание

a + b

plus(a,b)

Сложение в двоичной системе

a - b

minus(a,b)

Вычитание в двоичной системе

-a

uminus(a)

Унарный минус

+a

uplus(a)

Унарный плюс

a.*b

times(a,b)

Поэлементное умножение

a*b

mtimes(a,b)

Умножение матриц

a./b

rdivide(a,b)

Правильное поэлементное деление

a.\b

ldivide(a,b)

Покинутое поэлементное деление

a/b

mrdivide(a,b)

Матричное правое деление

a\b

mldivide(a,b)

Матричное левое деление

a.^b

power(a,b)

Поэлементная степень

a^b

mpower(a,b)

Матричная степень

a < b

lt(a,b)

Меньше, чем

a > b

gt(a,b)

Больше, чем

a <= b

le(a,b)

Меньше чем или равный

a >= b

ge(a,b)

Больше, чем или равный

a ~= b

ne(a,b)

Не равняются

a == b

eq(a,b)

Равенство

a & b

and(a,b)

Логический AND

a | b

or(a,b)

Логический OR

~a

not(a)

Логический НЕТ

a:d:b

a:b

colon(a,d,b)

colon(a,b)

Оператор двоеточия

a'

ctranspose(a)

Комплексное сопряженное транспонирование

a.'

transpose(a)

Матрица транспонирует

[a b]

horzcat(a,b,...)

Горизонтальная конкатенация

[a; b]

vertcatA, B

Вертикальная конкатенация

a(s1,s2,...sn)

subsref(a,s)

Преобразованная в нижний индекс ссылка

a(s1,...,sn) = b

subsasgn(a,s,b)

Преобразованное в нижний индекс присвоение

b(a)

subsindex(a)

Индекс индекса

Похожие темы