本文整理汇总了C++中TRnd::GetPowerDev方法的典型用法代码示例。如果您正苦于以下问题:C++ TRnd::GetPowerDev方法的具体用法?C++ TRnd::GetPowerDev怎么用?C++ TRnd::GetPowerDev使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类TRnd
的用法示例。
在下文中一共展示了TRnd::GetPowerDev方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: GenPLSeq
///Generate sequence from Power law
void TAGMUtil::GenPLSeq(TIntV& SzSeq, const int& SeqLen, const double& Alpha, TRnd& Rnd, const int& Min, const int& Max) {
SzSeq.Gen(SeqLen, 0);
while (SzSeq.Len() < SeqLen) {
int Sz = (int) TMath::Round(Rnd.GetPowerDev(Alpha));
if (Sz >= Min && Sz <= Max) {
SzSeq.Add(Sz);
}
}
}
示例2: GenRndPowerLaw
/// Generates a random scale-free graph with power-law degree distribution with
/// exponent PowerExp. The method uses either the Configuration model (fast but
/// the result is approximate) or the Edge Rewiring method (slow but exact).
PUNGraph GenRndPowerLaw(const int& Nodes, const double& PowerExp, const bool& ConfModel, TRnd& Rnd) {
TIntV DegSeqV;
uint DegSum=0;
for (int n = 0; n < Nodes; n++) {
const int Val = (int) TMath::Round(Rnd.GetPowerDev(PowerExp));
if (! (Val >= 1 && Val < Nodes/2)) { n--; continue; } // skip nodes with too large degree
DegSeqV.Add(Val);
DegSum += Val;
}
printf("%d nodes, %u edges\n", Nodes, DegSum);
if (DegSum % 2 == 1) { DegSeqV[0] += 1; }
if (ConfModel) {
// use configuration model -- fast but does not exactly obey the degree sequence
return GenConfModel(DegSeqV, Rnd);
} else {
PUNGraph G = TSnap::GenDegSeq(DegSeqV, Rnd);
return TSnap::GenRewire(G, 10, Rnd);
}
}