Формирование гипотез происходит в результате теоретического анализа модели решаемой задачи или может быть выполнено на основе статистических данных, получаемых в ходе вычислительных экспериментов с проектируемой программной системой.
Гипотеза 1: Стеки используются с одинаковой интенсивностью, память разделяется между стеками поровну.
Гипотеза 2: Интенсивность использования стеков различается.
Сохранение локальных тенденций роста:
правило распределение памяти для стеков в соответствии с их показателями роста
Гипотеза 3: Использование вероятностных предположений о поведении стеков.
Множество – набор элементов
int TBitField::GetBit(const int n) const
{
if ((n > -1) && (n < BitLen))
return (pMem[(GetMemIndex(n))] & (GetMemMask(n)));
else return(0);
}
void TBitField::SetBit(const int n)
{ if ((n > -1) && (n < BitLen))
pMem[(GetMemIndex(n))] |= GetMemMask(n);
}
void TBitField::ClrBit(const int n)
{ if ((n > -1) && (n < BitLen))
pMem[(GetMemIndex(n))] &= ~GetMemMask(n);
}
TBitField TBitField::operator|(const TBitField& bf)
{
int i, len;
if (BitLen > bf.BitLen)
len = BitLen;
else len = bf.BitLen;
TBitField temp(len);
for (i = 0; i < MemLen; i++)
temp.pMem[i] = pMem[i];
for (i = 0; i < bf.MemLen; i++)
temp.pMem[i] |= bf.pMem[i];
return temp;
}
TBitField TBitField::operator&(const TBitField &bf)
{
int i, len;
if (BitLen < bf.BitLen)
len = BitLen;
else len = bf.BitLen;
TBitField temp(len);
for (i = 0; i < MemLen; i++)
temp.pMem[i] = pMem[i];
for (i = 0; i < bf.MemLen; i++)
temp.pMem[i] &= bf.pMem[i];
return temp;
}
TBitField TBitField::operator~(void)
{
TBitField temp(BitLen);
for (int i = 0; i < MemLen; i++)
temp.pMem[i] = ~pMem[i];
return temp;
}
Универс U – множество всех элементов.
Конкретизация (допущения и ограничения):