Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 36, средняя оценка - 4.64
maxteam
2 / 2 / 0
Регистрация: 04.07.2010
Сообщений: 66
#1

Алгоритм BBS(Блюма — Блюма — Шубa) - C++

19.10.2010, 22:26. Просмотров 4758. Ответов 2
Метки нет (Все метки)

Здраствуйте!

Мне нужно смоделировать работу генератора случайных чисел с помощью метода ВВS (Блюма, Блюма и Шуба).

Формулу я нашел x_n = (x_ (n-1)) ^ 2 mod M, где M = p * q является произведением двух больших простых p и q. M и х0 у меня заданные (М = 111; Х0 = 56

я написал маленькую функцию для генерации чисел

C++
1
2
3
4
5
6
7
8
9
10
11
12
int x0=56;
 
int bbs()
{
 int M=111;
 static int x=x0;
 
 x=x*x % M;
 
 x0=x;
 return x;
}
(!) Я не могу понять одно:
"На каждом шаге алгоритма выходные данные выводят из xn путем взятия или бита четности, либо одного или нескольких наименее значимых бит xn" ...

У меня заданное количество бит равна 4.

То есть я не знаю как прикрутить еще это количество бит в общей формуле. Я так понял что мне надо взять "одного или нескольких наименее значимых бит xn" или я ошибаюсь?

Подскажите пожалуйста ...

Спасибо!
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.10.2010, 22:26     Алгоритм BBS(Блюма — Блюма — Шубa)
Посмотрите здесь:
Boot from bbs-harddisk
Генератор BBS вывод ответа Delphi
Delphi Генератором псевдослучайнных чисел BBS
BIOS Uefi hard disk drive bbs priorities - boot option #1-26
BIOS Горячие клавиши POST (загрузочное меню BIOS, Boot Menu, BBS POPUP, Boot Agent, Flash Utility...)
Волновой алгоритм поиска (Алгоритм A* / Алгоритм А стар) C++
Линейный алгоритм, Алгоритм с ветвлениями, Циклический алгоритм Линейный алгоритм Pascal
Построить алгоритм ДО и алгоритм ПОКА для вычислений значения функции на отрезке [a,b] с шагом h. Free Pascal
Составить алгоритм-вычисление квадрата суммы двух чисел и алгоритм для вычисления функции Pascal ABC
Построить алгоритм ДО и алгоритм ПОКА дя вычислений значения функции на отрезке [а,b] с шагом h. Написать программу Pascal
Написать алгоритм по блок схеме (Алгоритм метода Ньютона) Pascal

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Andrew_Lvov
Эксперт С++
259 / 189 / 5
Регистрация: 19.08.2010
Сообщений: 758
Записей в блоге: 1
19.10.2010, 23:17     Алгоритм BBS(Блюма — Блюма — Шубa) #2
Как я понимаю, вместо икса вам нужно возвращать бит или несколько (чем меншье - тем лучше).
В случае одного - либо бит чётности, либо последний бит.
Для генерации 16битного числа вам нужно 16 раз вызвать данную ф-цию и заполнить каждый бит числа.
maxteam
2 / 2 / 0
Регистрация: 04.07.2010
Сообщений: 66
14.12.2010, 18:00  [ТС]     Алгоритм BBS(Блюма — Блюма — Шубa) #3
вот моя прога
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <iostream>
/////////////////
int x0 = 56;
int M = 2111;
int n = 4;
/////////////////
int *bits;
int k=0;
int c=0;
 
int bbs();
int * dec2bin(int);
int check_bits(int *);
void generate(int,int);
 
int main()
{
    using std::cout;
    using std::cin;
    using std::endl;
 
    setlocale(0,"");
 
     int numbers = 0;
 
     cout<<"ÂâåäiГІГј ГЄiëüêiГ±ГІГј Г·ГЁГ±ГҐГ«: ";
     cin>>numbers;
     cout<<"ГЉiëüêiГ±ГІГј ГЎiГІ: ";
     cin>>n;
 
     generate(numbers,n);
    
 
 
     return 0;
}
 
int bbs()
{
    static int x=x0;
 
    x=x*x%M;
    c = x;
    x0 = x;
    
    return check_bits(dec2bin(x));
}
 
int * dec2bin(int z)
{   
    int i=1,j=1;
    int *t;
    t = (int*)calloc(100,sizeof(int));
    
    while(z>1)
    {
    *(t+i) = z%2;
    z=z/2; 
    i++;
    }
    
    k=i;
    bits = (int*)calloc(k,sizeof(int));
 
    int m = 1;
    *(bits+0)=z;
    for(j=i-1;j>0;j--,m++) {*(bits+m)=*(t+j);}
    
    free(t);
 
    return bits;
}
 
int check_bits(int *pbits)
{
    int bit_1 = 0;
    for(int i=0;i<k;i++) if(*(pbits+i) & 1) bit_1++;
 
    if(bit_1 % 2) return 0;
    else return 1;
}
 
void generate(int numbers,int n_bits)
{
    int *g = (int*)calloc(n_bits,sizeof(int));
    int rand = 0;
    int p;
    
    for(int j=0;j<numbers;j++)
    {
      p = n_bits-1;
      for(int i=0;i<n_bits;i++) 
      {
        *(g+i) = bbs();
        rand += *(g+i)*pow(2.0,p--);
      } 
 
      std::cout<<rand<<"; ";
      rand = 0;
    }
}
Yandex
Объявления
14.12.2010, 18:00     Алгоритм BBS(Блюма — Блюма — Шубa)
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru