我正在为特定种子生成一个随机数...因此,我有一个名为seed
的属性,允许用户设置该属性。我给他两个选择:reset
和trigger
。 reset
将重新开始随机数的生成。并且trigger
将生成下一个随机数。伪代码有点像
::setSeed( unsigned & seed )
{
m_seed = seed
}
::reset()
{
m_seed = getcurrentseed()
srand(m_seed);
}
::trigger()
{
raValue = minValue + ( rand() % (maxValue-minValue+1) );
}
对于一个特定的种子,如果我产生5次5次随机值..有时我会发现其中一组值缺失。可能是什么原因 ?
例如。
seed(5)
rand()
rand()
rand()
seed(5)
rand()
rand()
rand()
在第二次seed(5)调用之后,有时我会得到不同的数字序列,或者我错过了前一个序列的数字
void RandomNodeLogic::process( SingleInputValueGetters const& singleInputValueGetters
, MultiInputValueGetters const& /*multiInputValueGetters*/
, OutputValueKeepers const& /*outputValueKeepers */
, OutputValueSetters const& outputValueSetters )
{
// get the seed and generate the random number
bool doRandom( false );
int maxValue= getMaxValue().getAs<int>();
int minValue = getMinValue().getAs<int>();
int newValue=0;
if(minValue > maxValue)
{
setMaxValue(minValue);
setMinValue(maxValue);
maxValue= getMaxValue().getAs<int>();
minValue = getMinValue().getAs<int>();
}
SingleInputValueGetters::const_iterator it = singleInputValueGetters.begin();
for( ; it != singleInputValueGetters.end(); ++it)
{
SlotID id = it->first;
const SlotValue* value = it->second();
if(!value)
{
continue;
}
if ( id == RTT::LogicNetwork::RandomNode::nextValuesSlotID )
{
doRandom = value->getAs<bool>();
newValue = minValue + ( rand() % (maxValue-minValue+1) ); // read the value from the next input slot
setRandomValue( ::convertToSlotValue( m_genValue.m_attrType, newValue ) );
}
else if ( id == RTT::LogicNetwork::RandomNode::resetValuesSlotID )
{
if ( value->getAs<bool>() )
{
doRandom = value->getAs<bool>();
setSeed(m_seed);
newValue = minValue + ( rand() % (maxValue-minValue+1) );
setRandomValue( ::convertToSlotValue( m_genValue.m_attrType, newValue ) );
}
}
}
if(!m_genValue.empty() && doRandom)
{
outputValueSetters.find( RTT::LogicNetwork::RandomNode::outputValuesSlotID)->second( m_genValue.getAs<int>() ) ;
RTT_LOG_INFO( QString("Random Number: %1").arg( m_genValue.getAs<int>() ));
}
if(!doRandom)
{
if(m_genValue.empty())
{
srand(1);
m_genValue = 0;
}
getAssociatedNode()->sleep();
}
}
void RandomNodeLogic::setSeed( const SlotValue& seed )
{
SlotValue oldValue = m_seed;
m_seed = seed;
srand(m_seed.getAs<unsigned int>());
modifiablePropertyValueChanged( RTT::LogicNetwork::RandomNode::seedPropertyID, m_seed, oldValue );
}
最佳答案
到目前为止,您提供的所有信息都告诉我,您正在尝试为C随机函数编写C ++类包装器。即使此包装器是可以多次实例化的类,基础C函数也只能访问一个状态。这就是为什么您必须确保没有其他人正在使用此包装器类的实例。
这就是为什么用C ++类包装C的随机函数是一个坏主意的原因。作为随机进行的C ++练习,请尝试实现自己的随机类it's not as hard as it seems。