/* * 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 #include namespace thrust { namespace random { template linear_congruential_engine ::linear_congruential_engine(result_type s) { seed(s); } // end linear_congruential_engine::linear_congruential_engine() template void linear_congruential_engine ::seed(result_type s) { if((detail::mod(c) == 0) && (detail::mod(s) == 0)) m_x = detail::mod(1); else m_x = detail::mod(s); } // end linear_congruential_engine::seed() template typename linear_congruential_engine::result_type linear_congruential_engine ::operator()(void) { m_x = detail::mod(m_x); return m_x; } // end linear_congruential_engine::operator()() template void linear_congruential_engine ::discard(unsigned long long z) { thrust::random::detail::linear_congruential_engine_discard::discard(*this,z); } // end linear_congruential_engine::discard() template template std::basic_ostream& linear_congruential_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 & fill character const typename ios_base::fmtflags flags = os.flags(); const CharT fill = os.fill(); os.flags(ios_base::dec | ios_base::fixed | ios_base::left); os.fill(os.widen(' ')); // output one word of state os << m_x; // restore flags & fill character os.flags(flags); os.fill(fill); return os; } template template std::basic_istream& linear_congruential_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::dec); // input one word of state is >> m_x; // restore flags is.flags(flags); return is; } template bool linear_congruential_engine ::equal(const linear_congruential_engine &rhs) const { return m_x == rhs.m_x; } template __host__ __device__ bool operator==(const linear_congruential_engine &lhs, const linear_congruential_engine &rhs) { return detail::random_core_access::equal(lhs,rhs); } template bool operator!=(const linear_congruential_engine &lhs, const linear_congruential_engine &rhs) { return !(lhs == rhs); } template std::basic_ostream& operator<<(std::basic_ostream &os, const linear_congruential_engine &e) { return detail::random_core_access::stream_out(os,e); } template std::basic_istream& operator>>(std::basic_istream &is, linear_congruential_engine &e) { return detail::random_core_access::stream_in(is,e); } } // end random } // end thrust