/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * Copyright 2012 The MITRE Corporation * * * * Licensed under the Apache License, Version 2.0 (the "License"); * * you may not use this file except in compliance with the License. * * You may obtain a copy of the License at * * * * http://www.apache.org/licenses/LICENSE-2.0 * * * * Unless required by applicable law or agreed to in writing, software * * distributed under the License is distributed on an "AS IS" BASIS, * * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * * See the License for the specific language governing permissions and * * limitations under the License. * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ #include using namespace cv; using namespace br; /*! * \ingroup transforms * \brief Subtract two matrices. * \author Josh Klontz \cite jklontz */ class Subtract : public UntrainableMetaTransform { Q_OBJECT void project(const Template &src, Template &dst) const { if (src.size() != 2) qFatal("Subtract::project expected exactly two source images, got %d.", src.size()); dst.file = src.file; subtract(src[0], src[1], dst); } }; BR_REGISTER(Transform, Subtract) /*! * \ingroup transforms * \brief Take the absolute difference of two matrices. * \author Josh Klontz \cite jklontz */ class AbsDiff : public UntrainableMetaTransform { Q_OBJECT void project(const Template &src, Template &dst) const { if (src.size() != 2) qFatal("AbsDiff::project expected exactly two source images, got %d.", src.size()); dst.file = src.file; absdiff(src[0], src[1], dst); } }; BR_REGISTER(Transform, AbsDiff) /*! * \ingroup transforms * \brief Logical AND of two matrices. * \author Josh Klontz \cite jklontz */ class And : public UntrainableMetaTransform { Q_OBJECT void project(const Template &src, Template &dst) const { dst.file = src.file; dst.m() = src.first(); for (int i=1; i