📄 reduce.h
字号:
/***************************************************************************
* blitz/reduce.h Reduction operators: sum, mean, min, max,
* minIndex, maxIndex, product, count, any, all
*
* $Id: reduce.h,v 1.2 1998/03/14 00:04:47 tveldhui Exp $
*
* Copyright (C) 1997,1998 Todd Veldhuizen <tveldhui@seurat.uwaterloo.ca>
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* Suggestions: blitz-suggest@cybervision.com
* Bugs: blitz-bugs@cybervision.com
*
* For more information, please see the Blitz++ Home Page:
* http://seurat.uwaterloo.ca/blitz/
*
***************************************************************************
* $Log: reduce.h,v $
* Revision 1.2 1998/03/14 00:04:47 tveldhui
* 0.2-alpha-05
*
* Revision 1.1 1997/07/16 14:51:20 tveldhui
* Update: Alpha release 0.2 (Arrays)
*
*/
#ifndef BZ_REDUCE_H
#define BZ_REDUCE_H
#ifndef BZ_BLITZ_H
#include <blitz/blitz.h>
#endif
#ifndef BZ_NUMTRAIT_H
#include <blitz/numtrait.h>
#endif
#ifndef BZ_NUMINQUIRE_H
#include <blitz/numinquire.h>
#endif
BZ_NAMESPACE(blitz)
template<class P_sourcetype, class P_resulttype = BZ_SUMTYPE(P_sourcetype)>
class ReduceSum {
public:
typedef P_sourcetype T_sourcetype;
typedef P_resulttype T_resulttype;
typedef T_resulttype T_numtype;
enum { needIndex = 0, canProvideInitialValue = 1 };
ReduceSum()
{ reset(); }
ReduceSum(T_resulttype initialValue)
{ sum_ = initialValue; }
bool operator()(T_sourcetype x)
{
sum_ += x;
return true;
}
bool operator()(T_sourcetype x, int)
{
sum_ += x;
return true;
}
T_resulttype result(int)
{ return sum_; }
void reset()
{ sum_ = zero(T_resulttype()); }
void reset(T_resulttype initialValue)
{ sum_ = initialValue; }
static const char* name()
{ return "sum"; }
protected:
T_resulttype sum_;
};
template<class P_sourcetype, class P_resulttype = BZ_FLOATTYPE(P_sourcetype)>
class ReduceMean {
public:
typedef P_sourcetype T_sourcetype;
typedef P_resulttype T_resulttype;
typedef T_resulttype T_numtype;
enum { needIndex = 0, canProvideInitialValue = 0 };
ReduceMean()
{ reset(); }
ReduceMean(T_resulttype)
{
BZPRECHECK(0, "Provided an initial value for ReduceMean");
reset();
}
bool operator()(T_sourcetype x)
{
sum_ += x;
return true;
}
bool operator()(T_sourcetype x, int)
{
sum_ += x;
return true;
}
T_resulttype result(int count)
{ return sum_ / count; }
void reset()
{ sum_ = zero(T_resulttype()); }
void reset(T_resulttype)
{
BZPRECHECK(0, "Provided an initial value for ReduceMean");
reset();
}
static const char* name()
{ return "mean"; }
protected:
T_resulttype sum_;
};
template<class P_sourcetype>
class ReduceMin {
public:
typedef P_sourcetype T_sourcetype;
typedef P_sourcetype T_resulttype;
typedef T_resulttype T_numtype;
enum { needIndex = 0, canProvideInitialValue = 1 };
ReduceMin()
{ reset(); }
ReduceMin(T_resulttype min)
{
min_ = min;
}
bool operator()(T_sourcetype x)
{
if (x < min_)
min_ = x;
return true;
}
bool operator()(T_sourcetype x, int)
{
if (x < min_)
min_ = x;
return true;
}
T_resulttype result(int)
{ return min_; }
void reset()
{ min_ = huge(P_sourcetype()); }
void reset(T_resulttype initialValue)
{ min_ = initialValue; }
static const char* name()
{ return "min"; }
protected:
T_resulttype min_;
};
template<class P_sourcetype>
class ReduceMax {
public:
typedef P_sourcetype T_sourcetype;
typedef P_sourcetype T_resulttype;
typedef T_resulttype T_numtype;
enum { needIndex = 0, canProvideInitialValue = 1 };
ReduceMax()
{ reset(); }
ReduceMax(T_resulttype max)
{
max_ = max;
}
bool operator()(T_sourcetype x)
{
if (x > max_)
max_ = x;
return true;
}
bool operator()(T_sourcetype x, int)
{
if (x > max_)
max_ = x;
return true;
}
T_resulttype result(int)
{ return max_; }
void reset()
{ max_ = tiny(P_sourcetype()); }
void reset(T_resulttype initialValue)
{ max_ = initialValue; }
static const char* name()
{ return "max"; }
protected:
T_resulttype max_;
};
template<class P_sourcetype>
class ReduceMinIndex {
public:
typedef P_sourcetype T_sourcetype;
typedef int T_resulttype;
typedef T_resulttype T_numtype;
enum { needIndex = 1, canProvideInitialValue = 0 };
ReduceMinIndex()
{ reset(); }
ReduceMinIndex(T_resulttype min)
{
reset(min);
}
bool operator()(T_sourcetype x)
{
BZPRECONDITION(0);
return false;
}
bool operator()(T_sourcetype x, int index)
{
if (x < min_)
{
min_ = x;
index_ = index;
}
return true;
}
T_resulttype result(int)
{ return index_; }
void reset()
{
min_ = huge(T_sourcetype());
index_ = tiny(int());
}
void reset(T_resulttype)
{
BZPRECHECK(0, "Provided initial value for ReduceMinIndex");
reset();
}
static const char* name()
{ return "minIndex"; }
protected:
T_sourcetype min_;
int index_;
};
template<class P_sourcetype, int N>
class ReduceMinIndexVector {
public:
typedef P_sourcetype T_sourcetype;
typedef TinyVector<int,N> T_resulttype;
typedef T_resulttype T_numtype;
enum { canProvideInitialValue = 0 };
ReduceMinIndexVector()
{ reset(); }
ReduceMinIndexVector(T_resulttype min)
{
reset(min);
}
bool operator()(T_sourcetype x)
{
BZPRECONDITION(0);
return false;
}
bool operator()(T_sourcetype, int)
{
BZPRECONDITION(0);
return false;
}
bool operator()(T_sourcetype x, const TinyVector<int,N>& index)
{
if (x < min_)
{
min_ = x;
index_ = index;
}
return true;
}
T_resulttype result(int)
{ return index_; }
void reset()
{
min_ = huge(T_sourcetype());
index_ = tiny(int());
}
void reset(T_resulttype)
{
BZPRECHECK(0, "Provided initial value for ReduceMinIndex");
reset();
}
static const char* name()
{ return "minIndex"; }
protected:
T_sourcetype min_;
TinyVector<int,N> index_;
};
template<class P_sourcetype>
class ReduceMaxIndex {
public:
typedef P_sourcetype T_sourcetype;
typedef int T_resulttype;
typedef T_resulttype T_numtype;
enum { needIndex = 1, canProvideInitialValue = 0 };
ReduceMaxIndex()
{ reset(); }
ReduceMaxIndex(T_resulttype max)
{
reset(max);
}
bool operator()(T_sourcetype x)
{
BZPRECONDITION(0);
return false;
}
bool operator()(T_sourcetype x, int index)
{
if (x > max_)
{
max_ = x;
index_ = index;
}
return true;
}
T_resulttype result(int)
{ return index_; }
void reset()
{
max_ = tiny(T_sourcetype());
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -