/* * 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 namespace thrust { namespace random { template linear_feedback_shift_engine ::linear_feedback_shift_engine(result_type value) { seed(value); } // end linear_feedback_shift_engine::linear_feedback_shift_engine() template void linear_feedback_shift_engine ::seed(result_type value) { m_value = value; } // end linear_feedback_shift_engine::seed() template typename linear_feedback_shift_engine::result_type linear_feedback_shift_engine ::operator()(void) { const UIntType b = (((m_value << q) ^ m_value) & wordmask) >> (k-s); const UIntType mask = ( (~static_cast(0)) << (w-k) ) & wordmask; m_value = ((m_value & mask) << s) ^ b; return m_value; } // end linear_feedback_shift_engine::operator()() template void linear_feedback_shift_engine ::discard(unsigned long long z) { for(; z > 0; --z) { this->operator()(); } // end for } // end linear_feedback_shift_engine::discard() template template std::basic_ostream& linear_feedback_shift_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_value; // restore flags & fill character os.flags(flags); os.fill(fill); return os; } template template std::basic_istream& linear_feedback_shift_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 one word of state is >> m_value; // restore flags is.flags(flags); return is; } template bool linear_feedback_shift_engine ::equal(const linear_feedback_shift_engine &rhs) const { return m_value == rhs.m_value; } template bool operator==(const linear_feedback_shift_engine &lhs, const linear_feedback_shift_engine &rhs) { return thrust::random::detail::random_core_access::equal(lhs,rhs); } template bool operator!=(const linear_feedback_shift_engine &lhs, const linear_feedback_shift_engine &rhs) { return !(lhs == rhs); } template std::basic_ostream& operator<<(std::basic_ostream &os, const linear_feedback_shift_engine &e) { return thrust::random::detail::random_core_access::stream_out(os,e); } template std::basic_istream& operator>>(std::basic_istream &is, linear_feedback_shift_engine &e) { return thrust::random::detail::random_core_access::stream_in(is,e); } } // end random } // end thrust