>백엔드 개발 >C++ >가중치 난수 선택에 Boost의 난수 생성기를 어떻게 사용할 수 있습니까?

가중치 난수 선택에 Boost의 난수 생성기를 어떻게 사용할 수 있습니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-15 20:43:13552검색

How Can Boost's Random Number Generator Be Used for Weighted Random Number Selection?

가중 난수 생성

특정 확률을 갖는 난수를 선택하는 것은 프로그래밍에서 일반적인 작업입니다. Boost의 난수 생성기는 가중치가 적용된 확률로 항목을 선택하는 편리한 방법을 제공합니다.

다음 가중치를 사용하여 1에서 3 사이의 난수를 선택하려는 시나리오를 생각해 보세요.

  • 1: 90%
  • 2: 56%
  • 3: 4%

알고리즘

Boost에는 가중치 난수 생성 기능이 내장되어 있지 않습니다. 그러나 적용할 수 있는 간단한 알고리즘이 있습니다.

  1. 총 중량 계산: 모든 항목의 중량을 합산합니다.
  2. 난수: 0과 전체 사이에서 임의의 숫자를 선택하세요. 무게.
  3. 무게 반복: 숫자가 현재 항목의 무게보다 작아질 때까지 각 항목의 무게를 무작위 숫자에서 뺍니다.
  4. 반품아이템 : 난수가 음수가 된 위치에 해당하는 아이템이 선택됩니다. item.

코드 예

Boost에서 random_device 및 mt19937 난수 생성기 사용:

std::mt19937 rng(std::random_device{}());
int total_weight = 90 + 56 + 4;
for (int i = 0; i < total_weight; i++) {
    int random_number = rng() % total_weight;
    int current_weight = 90;
    if (random_number < current_weight) {
        return 1;
    }
    current_weight += 56;
    if (random_number < current_weight) {
        return 2;
    }
    return 3; // Reached the end of the weights
}

최적화

가중치가 거의 변하지 않는 경우 랜덤 픽이 빈번한 경우, 각 항목에 누적 가중치 합을 저장하여 최적화를 적용할 수 있습니다. 이를 통해 보다 효율적인 이진 검색 접근 방식이 가능해집니다.

또한 항목 수는 알 수 없지만 가중치는 알고 있는 경우 저장소 샘플링을 가중 난수 생성에 맞게 조정할 수 있습니다.

위 내용은 가중치 난수 선택에 Boost의 난수 생성기를 어떻게 사용할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.