/* * Copyright 2008-2012 NVIDIA 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 #include namespace thrust { namespace random { template xor_combine_engine ::xor_combine_engine(void) :m_b1(),m_b2() { } // end xor_combine_engine::xor_combine_engine() template xor_combine_engine ::xor_combine_engine(const base1_type &urng1, const base2_type &urng2) :m_b1(urng1),m_b2(urng2) { } // end xor_combine_engine::xor_combine_engine() template xor_combine_engine ::xor_combine_engine(result_type s) :m_b1(s),m_b2(s) { } // end xor_combine_engine::xor_combine_engine() template void xor_combine_engine ::seed(void) { m_b1.seed(); m_b2.seed(); } // end xor_combine_engine::seed() template void xor_combine_engine ::seed(result_type s) { m_b1.seed(s); m_b2.seed(s); } // end xor_combine_engine::seed() template const typename xor_combine_engine::base1_type & xor_combine_engine ::base1(void) const { return m_b1; } // end xor_combine_engine::base1() template const typename xor_combine_engine::base2_type & xor_combine_engine ::base2(void) const { return m_b2; } // end xor_combine_engine::base2() template typename xor_combine_engine::result_type xor_combine_engine ::operator()(void) { return (result_type(m_b1() - base1_type::min) << shift1) ^ (result_type(m_b2() - base2_type::min) << shift2); } // end xor_combine_engine::operator()() template void xor_combine_engine ::discard(unsigned long long z) { for(; z > 0; --z) { this->operator()(); } // end for } // end xor_combine_engine::discard() template template std::basic_ostream& xor_combine_engine ::stream_out(std::basic_ostream &os) const { typedef std::basic_ostream ostream_type; typedef typename ostream_type::ios_base ios_base; // save old flags and fill character const typename ios_base::fmtflags flags = os.flags(); const CharT fill = os.fill(); const CharT space = os.widen(' '); os.flags(ios_base::dec | ios_base::fixed | ios_base::left); os.fill(space); // output each base engine in turn os << base1() << space << base2(); // restore old flags and fill character os.flags(flags); os.fill(fill); return os; } template template std::basic_istream& xor_combine_engine ::stream_in(std::basic_istream &is) { typedef std::basic_istream istream_type; typedef typename istream_type::ios_base ios_base; // save old flags const typename ios_base::fmtflags flags = is.flags(); is.flags(ios_base::skipws); // input each base engine in turn is >> m_b1 >> m_b2; // restore old flags is.flags(flags); return is; } template bool xor_combine_engine ::equal(const xor_combine_engine &rhs) const { return (m_b1 == rhs.m_b1) && (m_b2 == rhs.m_b2); } template std::basic_ostream& operator<<(std::basic_ostream &os, const xor_combine_engine &e) { return thrust::random::detail::random_core_access::stream_out(os,e); } template std::basic_istream& operator>>(std::basic_istream &is, xor_combine_engine &e) { return thrust::random::detail::random_core_access::stream_in(is,e); } template bool operator==(const xor_combine_engine &lhs, const xor_combine_engine &rhs) { return thrust::random::detail::random_core_access::equal(lhs,rhs); } template bool operator!=(const xor_combine_engine &lhs, const xor_combine_engine &rhs) { return !(lhs == rhs); } } // end random } // end thrust