reforge "|" operator
[scilab.git] / scilab / modules / ast / tests / unit_tests / or.tst
1 // ============================================================================
2 // Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
3 // Copyright (C) 2014 - Scilab Enterprises - Antoine ELIAS
4 //
5 //  This file is distributed under the same license as the Scilab package.
6 // ============================================================================
7 //
8 // <-- JVM NOT MANDATORY -->
9
10 empty = [];
11 r = 2;
12 R = [1,2;3,4];
13 R3(:,:,1) = R;
14 R3(:,:,2) = R';
15 c = 1 + 2*%i;
16 C = [1+2*%i,2+4*%i;3+6*%i,4+8*%i];
17 C3(:,:,1) = C;
18 C3(:,:,2) = C';
19 e = eye();
20 ec = (5+%i) * eye();
21 p = 1 + %s - %s**2;
22 pc = 1 + %s - %s**2 + ( 2 - 3 * %s + 4 * %s**2 ) * %i;
23 P = [2*p, -3*p;4*p,-5*p];
24 PC = [2*pc, -3*pc;4*pc,-5*pc];
25 SP = sparse([1,2;4,5;3,10],[1,2,3]);
26 SPC = sparse([1,2;4,5;3,10],[1,2,3]) * ( 1 + 4*%i);
27 SPB = sparse([1,2;2,1],[%t;%t],[2,2]);
28
29 i8 = int8(-8);
30 ui8 = uint8(8);
31 I8 = int8([-8 -16 ; -24 -32]);
32 UI8 = uint8([8 16 ; 24 32]);
33
34 I16 = int16([-16 -32 ; -48 -64]);
35 UI16 = uint16([16 32 ; 48 64]);
36 i16 = int16(-16);
37 ui16 = uint16(16);
38
39 i32 = int32(-32);
40 ui32 = uint32(32);
41 I32 = int32([-32 -64 ; -96 -128]);
42 UI32 = uint32([32 64 ; 96 128]);
43
44 str = "string";
45 STR = ["string1" "string2";"string3" "string4"];
46
47 b = %f;
48 B = [%t %f;%f %t];
49
50
51 assert_checkequal(empty | empty, []);
52 assert_checkequal(empty | r, []);
53 assert_checkequal(empty | R, []);
54 assert_checkequal(empty | e, []);
55 assert_checkequal(empty | b, []);
56 assert_checkequal(empty | B, []);
57
58 assert_checkequal(r | empty, []);
59 assert_checkequal(r | r, %t);
60 assert_checkequal(r | R, [%t,%t;%t,%t]);
61 assert_checkequal(r | e, %t);
62 assert_checkequal(r | b, %t);
63 assert_checkequal(r | B, [%t,%t;%t,%t]);
64
65 assert_checkequal(R | empty, []);
66 assert_checkequal(R | r, [%t,%t;%t,%t]);
67 assert_checkequal(R | R, [%t,%t;%t,%t]);
68 assert_checkequal(R | e, [%t,%t;%t,%t]);
69 assert_checkequal(R | b, [%t,%t;%t,%t]);
70 assert_checkequal(R | B, [%t,%t;%t,%t]);
71
72 assert_checkequal(e | empty, []);
73 assert_checkequal(e | r, %t);
74 assert_checkequal(e | R, [%t,%t;%t,%t]);
75 assert_checkequal(e | b, %t);
76 assert_checkequal(e | B, [%t,%t;%t,%t]);
77
78 assert_checkequal(b | empty, []);
79 assert_checkequal(b | r, %t);
80 assert_checkequal(b | R, [%t,%t;%t,%t]);
81 assert_checkequal(b | e, %t);
82 assert_checkequal(b | b, %f);
83 assert_checkequal(b | B, [%t,%f;%f,%t]);
84 assert_checkequal(b | SPB, sparse([1,2;2,1],[%t;%t],[2,2]));
85
86 assert_checkequal(B | empty, []);
87 assert_checkequal(B | r, [%t,%t;%t,%t]);
88 assert_checkequal(B | R, [%t,%t;%t,%t]);
89 assert_checkequal(B | e, [%t,%t;%t,%t]);
90 assert_checkequal(B | b, [%t,%f;%f,%t]);
91 assert_checkequal(B | B, [%t,%f;%f,%t]);
92 assert_checkequal(B | SPB, sparse([1,1;1,2;2,1;2,2],[%t;%t;%t;%t],[2,2]));
93
94 assert_checkequal(SPB | b, sparse([1,2;2,1],[%t;%t],[2,2]));
95 assert_checkequal(SPB | B, sparse([1,1;1,2;2,1;2,2],[%t;%t;%t;%t],[2,2]));
96 assert_checkequal(SPB | SPB, sparse([1,2;2,1],[%t;%t],[2,2]));
97