Буль алгебрасы

Автор: Пользователь скрыл имя, 12 Ноября 2011 в 09:20, реферат

Описание работы

Жалпы алғанда буль функцияларының жалған және елеулі айнымалыларының дискреттік математикада ойнайтын рөлі өте зор. Бірінші оларды теориялық тұрғыдан қарастырайық. Буль функцияларының жалған және елеулі айнымалылары деп .............. атайды.
Бұл айнымалылардың маңызы өте зор. Мысалы, функция көп айнымалы болса, кейбір айнымалыларын (жалған айнымалыларды) алып тастауға болады. Ол бізге барлық параметрлер бойынша үнемдеуге мүмкіндік береді. Сондықтан осы үнемдеуді жүзеге асыратын программдық пакет құру актуалды мәселе. Бұл жұмыста қойылған мақсат бойынша бірінші теориялық, одан кейін программалық жүзеге асыру жүргізілді.

Содержание

Кіріспе..................................................................................3
Мазмұны 1
Кіріспе 2
Буль функцияларының жалған және елеулі айнымалылары 10
Есеп шығару мысалы 10
Буль функцияларының жалған және елеулі 12
айнымалыларын программада жүзеге асыру 12

Работа содержит 1 файл

Анар Омирбаева Информатика.doc

— 280.50 Кб (Скачать)

     Анықтама. Егер £ шарты орындалатын кез-келген және жинақтары үшін f ( )£f ( ) теңсіздігі орындалса, онда     f 1,...,хп) функциясы монотонды деп аталады.

     М арқылы барлық монотонды функциялар жиынын белгілейік. 0,1, х, x1 & х2, х1 v х2 Î М. М сыныбы тұйық.

     5. L - барлық сызықты функциялар сыныбы.

     0,1,x, ,x1Åx2ÎL ,x1&x2, х1 v х2ÏL. L сыныбы тұйық.

     Алгебра логикасының негізгі есептерінің бірі- толықтылықтың қажетті және жеткілікті шарттарын қарастырайық.

     Айталық G={f1,f2,..,f5,...} - Р2 жиынындағы кез-келген функциялар жүйесі болсын.

     Осы жүйенің толықтылығын калай анықтауға  болатынына келесі теорема береді.

     Теорема (функционалды толықтық туралы).

     G функциялар жүйесі толық болуы үшін оның келесі бес тұйық сыныптың T0,T1,S,M және L бірде біреуінде толығымен   жатпауы   қажетті де жеткілікті. 

     8.Пост нәтижелері

     Р2 жиынындағы тұйық сыныптарды американ математигі Э. Пост терең зерттеген. Ол Р2 жиынындағы барлық түйық сыныптардың құрылымы сипатталған.

     Анықтама. М тұйық сыныбындағы {f1,f2,…,fs,…} функциялар жүйесі толық деп аталады, егер оның тұйықтауы М сыныбымен беттеседі.

     Басқаша айтқанда, егер М сыныбындағы әрбір  функция берілген жиынның функциялары аркылы формула түрінде өрнектеле алса, онда М жиыны толық.

     Анықтама. Егер ол  М сыныбында толық , ал оның кез-келген өзіндік ішжиыны     М сыныбында толық болмаса, онда М тұйық сыныбындағы функциялар жүйесі {f1,f2,...,fs,...} оньщ базисі деп аталады. Мысалдар.

     1)f1=x1x2, f2=0, f3=1, f4=x1Åx2Åx3  функциялар жүйесі Р жиынының базисі боып табылады. Дәлелдеу:

       { x1x2,0,1,x1Åx2Åx3}- Р2 жиынында толық.

     { x1x2,0,1}- Р2 жиынында толық емес.

     2)  {0,1,x1&x2, х1 v х2} функциялар жүйесі М сыныбының базисі болып табылады.

     1 Пост теоремасы. Р2 жиынындағы әрбір тұйық сынып ақырлы базиске ие.

     2 Пост теоремасы. Р2 жиынындағы тұйық сыныптар жиынындағы қуаты санаулы.

    Буль  функцияларының жалған және елеулі айнымалылары

     Анықтама. Егер і-ші құрамдас бөлік бойынша көршілес және жинақтары табылатын болса, онда f (x1,…,xi-1,xi,xi+1,…,xn) функциясының xi (1£i£n) айнымалысы елеулі деп аталады (яғни

f ( )¹f ( ) қатынасы орындалатындай =(a1,...,ai-1,0,ai+1,…,an) және =(a1,...,ai-1,1,ai+1,…,an)  табылса). Кері жағдайда xi (1£i£n) айнымалысы f (x1,…,xi-1,xi,xi+1,…,xn) функциясының жалған айнымалысы деп аталады.

      Анықтама. Егер f ( ) және g( ) функциялардың маңызды айнымалылар жиыны бетессе және кез келген және  жинақтарда функциялардың мәндері бірдей болса:

f ( )=g( ),онда  f ( ) және g( ) функциялары тең деп аталады. Егер f ( ) және g( ) функциялары тең болса, онда олардың біреуін екіншісінен жалған айнымалыларды қосу немесе алып тастау арқылы алуға болады.

     

  • Есеп  шығару мысалы
  •       f( ) =(11110011) функциясының барлық жалған және елеулі айнымалыларын табу керек:

          ШЕШІМІ: Бұл функция үшін келесі кестені сызамыз: 
     

          x1   x2   x3 f( ) =( x1, x2, x3)
          0   0   0        0
          0   0   1        0
          0   1   0        1
          0   1   1        1
          1   0   0        1
          1   0   1        1
          1   1   0        0
          1   1   1        0

          x1: f(0,0,0)¹f(1,0,0) яғни, берілген функцияның мәндері сәйкес келмейтін жинақты табуға болады. Қорытынды  - x1айнымалысы f( ) функциясының елеулі аргументі.

          x2: f(1,0,0)¹ f(1,1,0), яғни x2 айнымалысы f( ) функциясының елеулі аргументі.

          x3: f(0,0,0)=f(0,0,1)=0, f(0,1,0)=f(0,1,1)=1, f(1,0,0)=f(1,0,1)=1, f(1,1,0)=f(1,1,1,)=0, яғни берілген функцияның мәндері барлық көршілес жинақтарда бірдей.

        Буль  функцияларының жалған және елеулі

      айнымалыларын программада жүзеге асыру

     

          Программалық  жүзеге асыру негізінен Delphi  ортасында  орындалды.Ол төменде көрсетілген: 

    unit Finder; 

    interface 

    uses

      Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,

      Dialogs, StdCtrls, ExtCtrls, Grids; 

    type

      TForm1 = class(TForm)

        ComboBox1: TComboBox;

        RadioGroup1: TRadioGroup;

        Button1: TButton;

        Edit1: TEdit;

        StringGrid1: TStringGrid;

        Button2: TButton;

        Button3: TButton;

        Label1: TLabel;

        Label2: TLabel;

        procedure Button1Click(Sender: TObject);

        procedure Edit1Click(Sender: TObject);

        procedure Button2Click(Sender: TObject);

        procedure Button3Click(Sender: TObject);

      private

        { Private declarations }

      public

        { Public declarations }

      end; 

    Type IntType = LongInt;

        Mas = Array [1..10000] Of IntType;

    var

      Form1     : TForm1;

      intVar    : IntType;

      mT        : Mas; 

    implementation 

    {$R *.dfm} 

    FUNCTION Power(X : IntType; P : IntType) : IntType;

    Var Ret : IntType;

        i  :IntType;

    Begin

      If (p=0)or(x=1) then

      Begin

        Power:=1;

        Exit;

      End;

      Ret:=1;

      For i:=1 to P do

      Begin

        Ret:=Ret*X;

      End;

      Power:=Ret;

    End; 

    FUNCTION Meaning(X,Y : IntType) : IntType;

    Var j, Ret : IntType;

    Begin

      If X=1 then

      Begin

        Meaning:=0;

        Exit;

      End;

      Ret:=0;

      x:=x-1;

      For j:=1 to Y do

      Begin

        Ret:=X mod 2;

        X:=X div 2;

      End;

      Meaning:=Ret;

    End; 

    procedure TForm1.Button1Click(Sender: TObject);

    Var i, j : IntType;

    begin

      If RadioGroup1.ItemIndex=-1 then

      Begin

        ShowMessage('Выберите функцию');

        Exit;

      End Else

      If RadioGroup1.ItemIndex=0 then

      Begin

        Try

          intVar:=StrToInt(Edit1.Text);

        Except

          ShowMessage('Ввведите, все-таки, кол-во переменных');

          Exit;

        End;

      //Строим таблицу для удобства

        StringGrid1.Visible:=True;

        StringGrid1.ColCount:=intVar+1;

        StringGrid1.RowCount:=Power(2,intVar)+1;

        For i:=1 to StringGrid1.ColCount-1 do

          StringGrid1.Cells[i,0]:='x'+IntToStr(i);

        For i:=1 to StringGrid1.RowCount-1 do

          StringGrid1.Cells[0,i]:=IntToStr(i)+')';

        StringGrid1.ColCount:=StringGrid1.ColCount+1;

        StringGrid1.Cells[StringGrid1.ColCount-1,0]:='Function Value';

        Button2.Visible:=True;

        For i:=1 to StringGrid1.RowCount-1 do

          For j:=1 to StringGrid1.ColCount-2 do

            StringGrid1.Cells[j,i]:=IntToStr(Meaning(i,StringGrid1.ColCount-2-j+1));

      End

      Else

      If RadioGroup1.ItemIndex=1 then

      Begin

        StringGrid1.Visible:=True;

        Button3.Visible:=True;

        StringGrid1.EditorMode:=True;

    Информация о работе Буль алгебрасы