simple_components_4.68.0_da9b0f3a/test_components/test_blackboard_performance.adb

  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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
--                                                                    --
--  procedure                       Copyright (c)  Dmitry A. Kazakov  --
--     Test_Blackboard_Performance                 Luebeck            --
--  Test blackboard operations performance         Autumn, 2009       --
--                                                                    --
--                                Last revision :  23:22 29 Sep 2017  --
--                                                                    --
--  This  library  is  free software; you can redistribute it and/or  --
--  modify it under the terms of the GNU General Public  License  as  --
--  published by the Free Software Foundation; either version  2  of  --
--  the License, or (at your option) any later version. This library  --
--  is distributed in the hope that it will be useful,  but  WITHOUT  --
--  ANY   WARRANTY;   without   even   the   implied   warranty   of  --
--  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU  --
--  General  Public  License  for  more  details.  You  should  have  --
--  received  a  copy  of  the GNU General Public License along with  --
--  this library; if not, write to  the  Free  Software  Foundation,  --
--  Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.    --
--                                                                    --
--  As a special exception, if other files instantiate generics from  --
--  this unit, or you link this unit with other files to produce  an  --
--  executable, this unit does not by  itself  cause  the  resulting  --
--  executable to be covered by the GNU General Public License. This  --
--  exception  does not however invalidate any other reasons why the  --
--  executable file might be covered by the GNU Public License.       --
--____________________________________________________________________--

with Ada.Exceptions;           use Ada.Exceptions;
with Ada.Real_Time;            use Ada.Real_Time;
with Ada.Text_IO;              use Ada.Text_IO;
with System.Storage_Elements;  use System.Storage_Elements;
with Test_Record_Blackboards;  use Test_Record_Blackboards;

procedure Test_Blackboard_Performance is

   Rounds : constant := 5_000_000;
   use Boards;

   procedure Report
             (  Text   : String;
                Span   : Time_Span;
                Rounds : Integer
             )  is
      type Nanoseconds is delta 0.1 range -100.0..1_000_000.0;
   begin
      Put_Line
      (  Text
      &  Nanoseconds'Image
         (  Nanoseconds
            (  Float (To_Duration (Span)) * 1.0E9
            /  Float (Rounds)
         )  )
      &  " ns"
      );
   end Report;

   type Blackboard_Ptr is access Blackboard;
   T1, T2, T3 : Time;
begin
   delay 0.001; -- GNAT bug workaround
   declare
      Data_Ptr : constant Blackboard_Ptr := -- Don't allocate it on the
                    new Blackboard          -- stack
                        (  (2 * Rounds + 1)
                        *  (  (  Element'Size
                              +  Storage_Element'Size
                              -  1
                              )
                           /  Storage_Element'Size
                        )  );
      Data : Blackboard renames Data_Ptr.all;
      Item : Element;
      This : Reference;
   begin
      T1 := Clock;
      for I in 1..Rounds loop
         Put (Data, (others => 0));
      end loop;
      T2 := Clock;
      for I in 1..Rounds loop
         Put (Data, (others => 0));
         Put (Data, (others => 0));
      end loop;
      T3 := Clock;
      Report ("writing blackboard", T3 - T2 - (T2 - T1), Rounds);
      T1 := Clock;

      This := First (Data);
      T1 := Clock;
      for I in 1..Rounds loop
         Item := Get (Data, This);
      end loop;
      This := First (Data);
      T2 := Clock;
      for I in 1..Rounds loop
         Item := Get (Data, This);
         Item := Get (Data, This);
      end loop;
      T3 := Clock;
      Report ("reading blackboard", T3 - T2 - (T2 - T1), Rounds);
      T1 := Clock;

      T1 := Clock;
      for I in 1..Rounds * 10 loop
         Item (1) := Item (I mod 10 + 1);
         Item := (others => 0);
      end loop;
      T2 := Clock;
      for I in 1..Rounds * 10 loop
         Item := (others => 0);
         Item (1) := Item (I mod 10 + 1);
         Item := (others => 1);
      end loop;
      T3 := Clock;
      Report ("raw writing", T3 - T2 - (T2 - T1), Rounds * 10);
      T1 := Clock;

   end;
exception
   when Error : others =>
      Put_Line ("Error: " & Exception_Information (Error));
end Test_Blackboard_Performance;