Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037 #ifndef __SPART_UTIL__SUBPSA_H__
00038 #define __SPART_UTIL__SUBPSA_H__
00039
00040 #include "rect_list.hpp"
00041
00042 namespace util
00043 {
00044
00055 template <typename T, typename Pr>
00056 class SubPSA
00057 {
00059 const Pr& originalpsa;
00061 rectangle subspace;
00062
00066 class Intermediate
00067 {
00068 const Pr& originalpsa;
00069 const rectangle& subspace;
00070 int x;
00071
00072 public:
00073 Intermediate (const Pr& psa, const rectangle& r, int xval)
00074 :originalpsa(psa), subspace(r), x(xval)
00075 {
00076 }
00077
00078 T operator[] (int y) const
00079 {
00080 assert (y >= 0);
00081 assert (y < subspace.y_bot_r - subspace.y_top_l + 2);
00082
00083 return originalpsa[x+subspace.x_top_l-1][y+subspace.y_top_l-1]
00084 +originalpsa[subspace.x_top_l-1][subspace.y_top_l-1]
00085 -originalpsa[x+subspace.x_top_l-1][subspace.y_top_l-1]
00086 -originalpsa[subspace.x_top_l-1][y+subspace.y_top_l-1];
00087 }
00088 };
00089
00090 public:
00091 SubPSA (const Pr& psa, const rectangle& r)
00092 :originalpsa(psa), subspace(r)
00093 {
00094 assert (!subspace.empty());
00095 assert (subspace.valid_bound(originalpsa));
00096 }
00097
00098
00102 int prefixsizeX () const
00103 {
00104 return subspace.x_bot_r - subspace.x_top_l + 2;
00105 }
00106
00110 int prefixsizeY () const
00111 {
00112 return subspace.y_bot_r - subspace.y_top_l + 2;
00113 }
00114
00115 Intermediate operator[] (int x) const
00116 {
00117 assert (x >= 0);
00118 assert (x < prefixsizeX());
00119 return Intermediate(originalpsa,subspace,x);
00120 }
00121
00126 rectangle inOriginalSpace (const rectangle& r)
00127 {
00128
00129 return rectangle( r.x_top_l+subspace.x_top_l-1,
00130 r.x_bot_r+subspace.x_top_l-1,
00131 r.y_top_l+subspace.y_top_l-1,
00132 r.y_bot_r+subspace.y_top_l-1);
00133
00134
00135 }
00136 };
00137 }
00138
00139 #endif