本文整理汇总了C++中vsip_csl类的典型用法代码示例。如果您正苦于以下问题:C++ vsip_csl类的具体用法?C++ vsip_csl怎么用?C++ vsip_csl使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了vsip_csl类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: test_view_cast
void
test_view_cast(length_type size)
{
Vector<T1> src(size);
Vector<T2> dst(size);
Rand<T1> rand(0);
src = T1(100) * rand.randu(size);
dst = vsip_csl::view_cast<T2>(src);
for (index_type i=0; i<size; ++i)
test_assert(equal(dst.get(i),
static_cast<T2>(src.get(i))));
src = ramp(T1(0), T1(1), size);
dst = vsip_csl::view_cast<T2>(src);
T1 src_sum = expect_vector<T1>(src);
T2 dst_sum = expect_vector<T2>(vsip_csl::view_cast<T2>(src));
for (index_type i=0; i<size; ++i)
test_assert(equal(dst.get(i),
static_cast<T2>(src.get(i))));
test_assert(equal(dst_sum, static_cast<T2>(src_sum)));
}
示例2: test_ukernel
void
test_ukernel(length_type rows, length_type cols)
{
Madd_kernel obj;
vsip_csl::ukernel::Ukernel<Madd_kernel> madd_uk(obj);
Matrix<T1> in0(rows, cols);
Matrix<T2> in1(rows, cols);
Matrix<T2> in2(rows, cols);
Matrix<T2> out(rows, cols);
Rand<T1> gen1(0, 0);
in0 = gen1.randu(rows, cols);
Rand<T2> gen2(1, 0);
in1 = gen2.randu(rows, cols);
in2 = gen2.randu(rows, cols);
madd_uk(in0, in1, in2, out);
for (index_type i=0; i < rows; ++i)
for (index_type j=0; j < cols; ++j)
{
T2 madd = in0.get(i, j) * in1.get(i, j) + in2.get(i, j);
if (!equal(madd, out.get(i, j)))
{
std::cout << "index " << i << ", " << j << " : "
<< in0.get(i, j) << " * "
<< in1.get(i, j) << " + "
<< in2.get(i, j) << " = "
<< in0.get(i, j) * in1.get(i, j) + in2.get(i, j) << " vs "
<< out.get(i, j)
<< std::endl;
}
test_assert(equal(
in0.get(i, j) * in1.get(i, j) + in2.get(i, j),
out.get(i, j)));
}
}
示例3: A
void
test_vmul(length_type size)
{
typedef impl::Layout<1, row1_type, impl::Stride_unit_dense, ComplexFmt>
LP;
typedef impl::Fast_block<1, T, LP> block_type;
Vector<T, block_type> A(size, T(3));
Vector<T, block_type> B(size, T(4));
Vector<T, block_type> Z(size);
Rand<T> gen(0, 0);
A = gen.randu(size);
B = gen.randu(size);
Z = A * B;
for (index_type i=0; i<size; ++i)
{
// Note: almost_equal is necessary for Cbe since SPE and PPE will not
// compute idential results.
#if VERBOSE
if (!almost_equal(Z(i), A(i) * B(i)))
{
std::cout << "Z(i) = " << Z(i) << std::endl;
std::cout << "A(i) * B(i) = " << A(i) * B(i) << std::endl;
}
#endif
test_assert(almost_equal(Z.get(i), A(i) * B(i)));
}
}
示例4: uk
void
test_ukernel(length_type size)
{
Id1 cuk;
Ukernel<Id1> uk(cuk);
Vector<T> in(size);
Vector<T> out(size);
in = ramp<T>(0, 0.1, size);
uk(in, out);
for (index_type i=0; i<size; ++i)
{
if (!equal(out.get(i), in.get(i) + T(i)))
{
std::cout << i << ": " << out.get(i) << " != "
<< in.get(i) << " + " << T(i)
<< std::endl;
}
test_assert(equal(out.get(i), in.get(i) + T(i)));
}
}
示例5: T
void
test_funcall()
{
length_type const len = 10;
Vector<T> v1(len, T());
Vector<T> v2(len, T());
Vector<T> v3(len, T());
v1.put(1, T(1));
v2.put(1, T(2));
v3.put(1, T(3));
T s1 = sum(v1);
T s2 = sum(t_add(v1, v2));
const_Vector<T, expr::Binary<expr::op::Add, Dense<1, T>, Dense<1, T>, true> const> vx(t_add(v1, v2));
T s3 = sum(vx);
T s4 = sum(t_add(t_mul(v2, v3), t_neg(t_add(v1, v3))));
#if ILLEGALCASE == 1
// It should not be possible to pass an expression template (which is
// a const_Vector) to a function expecting a Vector.
T s5 = vector_sum(t_add(t_mul(v2, v3), t_neg(t_add(v1, v3))));
#endif
test_assert(equal(s1, T(1)));
test_assert(equal(s2, T(3)));
test_assert(equal(s3, T(3)));
test_assert(equal(s4, T(2)));
}
示例6: T
void
test_transpose_readonly(MatrixT view)
{
typedef typename MatrixT::value_type T;
// Check that view is initialized
check_matrix(view, 0);
length_type const size1 = view.size(1);
typename MatrixT::const_transpose_type trans = view.transpose();
test_assert(trans.size(0) == view.size(1));
test_assert(trans.size(1) == view.size(0));
for (index_type idx0=0; idx0<trans.size(0); ++idx0)
for (index_type idx1=0; idx1<trans.size(1); ++idx1)
{
T expected = T(idx1 * size1 + idx0 + 0);
test_assert(equal(trans.get(idx0, idx1), expected));
test_assert(equal(trans.get(idx0, idx1),
view. get(idx1, idx0)));
}
// Check that view is unchanged
check_matrix(view, 0);
}
示例7: T
void
test_view(const_Vector<complex<T>, Block> vec, int k)
{
for (index_type i=0; i<vec.size(0); ++i)
{
if (!equal(vec.get(i), complex<T>(T(k*i+1), T(k*i+2))))
{
cout << "ERROR: i = " << i << endl
<< " Got = " << vec.get(i) << endl
<< " expected = " << vec.get(i) << endl;
}
test_assert(equal(vec.get(i), complex<T>(T(k*i+1), T(k*i+2))));
}
}
示例8: operator
void operator()(length_type size, length_type loop, float& time)
{
Vector<T> A(size, T());
Vector<T> Z(size);
#if 0
// int const no_times = 0; // FFTW_PATIENT
int const no_times = 15; // not > 12 = FFT_MEASURE
typedef Fft<const_Vector, T, T, fft_fwd, by_reference, no_times, alg_time>
fft_type;
#else
typedef ErsatzFFT<-1, T> fft_type;
#endif
fft_type fft(Domain<1>(size), 1.f);
A = T(1);
vsip::impl::profile::Timer t1;
t1.start();
for (index_type l=0; l<loop; ++l)
fft(A, Z);
t1.stop();
if (!equal(Z(0), T(size)))
{
std::cout << "t_fft: ERROR" << std::endl;
abort();
}
time = t1.delta();
}
示例9: fftm
void
test_fftm_op_align(
length_type rows,
length_type size,
length_type gap,
length_type align)
{
#if VERBOSE
std::cout << "fftm_op_align(" << rows << " x " << size
<< ", gap " << gap
<< ", align " << align << ")\n";
#endif
typedef impl::Stride_unit_dense sud_type;
typedef impl::Layout<2, row2_type, sud_type, ComplexFmt> lp_type;
typedef impl::Fast_block<2, T, lp_type> block_type;
typedef Fftm<T, T, row, fft_fwd, by_reference, 1, alg_space> fftm_type;
fftm_type fftm(Domain<2>(rows, size), 1.f);
Matrix<T, block_type> in (rows, size + gap);
Matrix<T, block_type> out(rows, size + gap);
for (index_type i=0; i<rows; ++i)
in.row(i) = T(i+1);
fftm(in (Domain<2>(rows, Domain<1>(align, 1, size))),
out(Domain<2>(rows, Domain<1>(align, 1, size))));
for (index_type i=0; i<rows; ++i)
{
T got = out.get(i, align);
#if VERBOSE
if (!equal(got, T((i+1)*size)))
{
std::cout << "Error: row " << i << std::endl
<< " : expected " << T((i+1)*size) << std::endl
<< " : got " << got << std::endl
<< " : got " << out.get(i, align) << std::endl
;
}
#endif
test_assert(equal(got, T((i+1)*size)));
}
}
示例10: fun
bool
check_interleaved_array(
T* data,
Domain<Dim> const& dom,
Func fun)
{
Length<Dim> ext = impl::extent(dom);
for (Index<Dim> idx; valid(ext,idx); next(ext, idx))
{
index_type i = to_index<Order>(ext, idx);
complex<T> val = fun(i);
if (!equal(data[2*i+0], val.real()) ||
!equal(data[2*i+1], val.imag()))
return false;
}
return true;
}
示例11: block
void
test_1_low()
{
length_type const size = 10;
typedef typename Block::value_type value_type;
Block block(size, 0.0);
value_type val0 = 1.0f;
value_type val1 = 2.78f;
value_type val2 = 3.14f;
value_type val3 = -1.5f;
// Place values in block.
block.put(0, val0);
block.put(1, val1);
{
vsip::dda::impl::Accessor<Block,
typename Block::layout_type,
AccessTag>
raw(block);
// Check properties of LLDI.
test_assert(raw.stride(&block, 0) == 1);
test_assert(raw.size(&block, 0) == size);
float* data = raw.ptr(&block);
raw.begin(&block, true);
// Check that block values are reflected.
test_assert(equal(data[0], val0));
test_assert(equal(data[1], val1));
// Place values in raw data.
data[1] = val2;
data[2] = val3;
raw.end(&block, true);
}
// Check that raw data values are reflected.
test_assert(equal(block.get(1), val2));
test_assert(equal(block.get(2), val3));
}
示例12: exec
void exec(length_type rows, length_type cols, length_type loop, float& time)
{
Matrix<T1, src_block_t> A(rows, cols);
Matrix<T2, dst_block_t> Z(rows, cols, T2());
for (index_type i = 0; i < rows; ++i)
for (index_type j = 0; j < cols; ++j)
A.put(i, j, T1(i * cols + j, -0.5));
// Scoping is used to control the lifetime of Ext_data<> objects. These
// must be destroyed before accessing data through the view again.
{
impl::cuda::Device_memory<src_block_t const> dev_a(A.block());
impl::cuda::Device_memory<dst_block_t> dev_z(Z.block());
T1 const* pA = dev_a.data();
T2* pZ = dev_z.data();
// Benchmark the operation
vsip::impl::profile::Timer t1;
t1.start();
for (index_type l = 0; l < loop; ++l)
{
this->functor_(pA, pZ, rows, cols);
cudaThreadSynchronize();
}
t1.stop();
time = t1.delta();
}
// validate results
for (index_type i = 0; i < rows; ++i)
for (index_type j = 0; j < cols; ++j)
{
#if DEBUG
if (!equal(F::apply(A.get(i, j)), Z.get(i, j)))
{
cout << "ERROR: at location " << i << ", " << j << endl
<< " expected: " << F::apply(A.get(i, j)) << endl
<< " got : " << Z.get(i, j) << endl;
}
#endif
test_assert(equal(F::apply(A.get(i, j)), Z.get(i, j)));
}
}
示例13: a
void
test_real_subview_vector_freqswap( length_type m )
{
Vector<complex<T> > a(m);
a.real() = ramp<T>(0, 1, m);
a.imag() = T(0);
Vector<T> b(m);
Vector<complex<T> > c(m, T());
b = vsip::freqswap(a.real());
c.real() = a.real(); c.real() = vsip::freqswap(c.real());
for ( index_type i = 0; i < m; i++ )
{
test_assert(equal( b.get(i), a.real().get(((m+1)/2 + i) % m ) ));
test_assert(equal( c.real().get(i), a.real().get(((m+1)/2 + i) % m ) ));
}
}
示例14: operator
void operator()(length_type size, length_type loop, float& time)
{
using namespace vsip::impl;
typedef Dense<1,T,row1_type,MapT> block_type;
typedef reduction_op_eval<Max_value,T,block_type,1,Tag> eval;
create_test_vector_helper<MapT,Vector,float,Dense<1,T,row1_type,MapT> >
ctvh(size);
T val = T();
Index<1> idx;
Rand<T> gen(0, 0);
if (init_ == 0)
ctvh.assign_view(gen.randu(size));
else if (init_ == 1)
ctvh.assign_view(ramp(T(0), T(1), size));
else if (init_ == 2)
ctvh.assign_view(ramp(T(size-1), T(-1), size));
vsip::impl::profile::Timer t1;
t1.start();
for (index_type l=0; l<loop; ++l)
eval::exec(val, ctvh.view.block(), idx);
t1.stop();
if (init_ == 1)
{
test_assert(equal(val, T(size-1)));
test_assert(idx == size-1);
}
else if (init_ == 2)
{
test_assert(equal(val, T(size-1)));
test_assert(idx == 0);
}
time = t1.delta();
}
示例15: a
void
test_cvjdot_rand(length_type m)
{
typedef typename Promotion<T0, T1>::type return_type;
typedef typename vsip::impl::Scalar_of<return_type>::type scalar_type;
Vector<T0> a(m);
Vector<T1> b(m);
randv(a);
randv(b);
// Test vector-vector prod
return_type val = cvjdot(a, b);
return_type chk1 = dot(a, conj(b));
return_type chk2 = ref::dot(a, conj(b));
test_assert(equal(val, chk1));
test_assert(equal(val, chk2));
}