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
00038
00039
00040
00041
00042 #ifndef PLAYA_DEFAULTBLOCKVECTORSPACEIMPL_HPP
00043 #define PLAYA_DEFAULTBLOCKVECTORSPACEIMPL_HPP
00044
00045 #include "PlayaDefaultBlockVectorSpaceDecl.hpp"
00046 #include "PlayaDefaultBlockVectorDecl.hpp"
00047 #include "PlayaVectorSpaceDecl.hpp"
00048 #include "PlayaExceptions.hpp"
00049
00050 namespace Playa
00051 {
00052
00053 template <class Scalar> inline
00054 DefaultBlockVectorSpace<Scalar>::
00055 DefaultBlockVectorSpace(const Array<VectorSpace<Scalar> >& blocks)
00056 : blocks_(blocks), baseGNI_(-1)
00057 {
00058 baseGNI_ = this->accumulateBaseGNI();
00059 }
00060
00061 template <class Scalar> inline
00062 const VectorSpace<Scalar>&
00063 DefaultBlockVectorSpace<Scalar>::getBlock(int b) const
00064 {
00065 TEUCHOS_TEST_FOR_EXCEPTION(b < 0 || b >= this->numBlocks(),
00066 RuntimeError, "block index b=" << b << " into vector space "
00067 << this->description() << " out of range [0,"
00068 << this->numBlocks() << ")");
00069 return blocks_[b];
00070 }
00071
00072
00073 template <class Scalar> inline
00074 RCP<VectorBase<Scalar> > DefaultBlockVectorSpace<Scalar>
00075 ::createMember(const VectorSpace<Scalar>& self) const
00076 {
00077 TEUCHOS_TEST_FOR_EXCEPTION(this != self.ptr().get(), RuntimeError,
00078 "inconsistent self-reference in DefaultBlockVectorSpace::"
00079 "createMember()");
00080 return rcp(new DefaultBlockVector<Scalar>(self));
00081 }
00082
00083
00084 template <class Scalar> inline
00085 const MPIComm& DefaultBlockVectorSpace<Scalar>::comm() const
00086 {
00087 return getBlock(0).comm();
00088 }
00089
00090 template <class Scalar> inline
00091 int DefaultBlockVectorSpace<Scalar>::baseGlobalNaturalIndex() const
00092 {
00093 return baseGNI_;
00094 }
00095
00096
00097
00098
00099
00100 template <class Scalar> inline
00101 VectorSpace<Scalar> blockSpace(
00102 const VectorSpace<Scalar>& v1)
00103 {
00104 Array<VectorSpace<Scalar> > x(1);
00105 x[0] = v1;
00106 return blockSpace<Scalar>(x);
00107 }
00108
00109
00110
00111 template <class Scalar> inline
00112 VectorSpace<Scalar> blockSpace(
00113 const VectorSpace<Scalar>& v1,
00114 const VectorSpace<Scalar>& v2)
00115 {
00116 Array<VectorSpace<Scalar> > x(2);
00117 x[0] = v1;
00118 x[1] = v2;
00119 return blockSpace<Scalar>(x);
00120 }
00121
00122
00123 template <class Scalar> inline
00124 VectorSpace<Scalar> blockSpace(
00125 const VectorSpace<Scalar>& v1,
00126 const VectorSpace<Scalar>& v2,
00127 const VectorSpace<Scalar>& v3)
00128 {
00129 Array<VectorSpace<Scalar> > x(3);
00130 x[0] = v1;
00131 x[1] = v2;
00132 x[2] = v3;
00133 return blockSpace<Scalar>(x);
00134 }
00135
00136
00137 template <class Scalar> inline
00138 VectorSpace<Scalar> blockSpace(
00139 const VectorSpace<Scalar>& v1,
00140 const VectorSpace<Scalar>& v2,
00141 const VectorSpace<Scalar>& v3,
00142 const VectorSpace<Scalar>& v4)
00143 {
00144 Array<VectorSpace<Scalar> > x(4);
00145 x[0] = v1;
00146 x[1] = v2;
00147 x[2] = v3;
00148 x[3] = v4;
00149 return blockSpace<Scalar>(x);
00150 }
00151
00152
00153 template <class Scalar> inline
00154 VectorSpace<Scalar> blockSpace(const Array<VectorSpace<Scalar> >& x)
00155 {
00156 RCP<const VectorSpaceBase<Scalar> > rtn
00157 = rcp(new DefaultBlockVectorSpace<Scalar>(x));
00158 return rtn;
00159 }
00160
00161
00162 }
00163
00164
00165
00166
00167 #endif