File: shifta_01.f90

package info (click to toggle)
lfortran 0.58.0-4
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 54,512 kB
  • sloc: cpp: 162,179; f90: 68,251; python: 17,476; ansic: 6,278; yacc: 2,334; sh: 1,317; fortran: 892; makefile: 33; javascript: 15
file content (53 lines) | stat: -rw-r--r-- 1,509 bytes parent folder | download | duplicates (3)
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
program shifta_01
    implicit none
    integer(kind=4) :: n, x, result

    ! Test case 1: shift by 0 bits
    n = 12345678
    x = 0
    result = shifta(n, x)
    print *, "Test case 1: shifta(", n, ",", x, ") = ", result
    if (result /= n) error stop "Test case 1 failed"

    ! Test case 2: shift by 1 bit
    n = 12345678
    x = 1
    result = shifta(n, x)
    print *, "Test case 2: shifta(", n, ",", x, ") = ", result
    if (result /= 6172839) error stop "Test case 2 failed"

    ! Test case 3: shift by 15 bits
    n = 12345678
    x = 15
    result = shifta(n, x)
    print *, "Test case 3: shifta(", n, ",", x, ") = ", result
    if (result /= 376) error stop "Test case 3 failed"

    ! Test case 4: shift by 16 bits
    n = 12345678
    x = 16
    result = shifta(n, x)
    print *, "Test case 4: shifta(", n, ",", x, ") = ", result
    if (result /= 188) error stop "Test case 4 failed"

    ! Test case 5: shift by 30 bits
    n = 2**29
    x = 30
    result = shifta(n, x)
    print *, "Test case 5: shifta(", n, ",", x, ") = ", result
    if (result /= 0) error stop "Test case 5 failed"

    n = 2**30
    x = 30
    result = shifta(n, x)
    print *, "Test case 5: shifta(", n, ",", x, ") = ", result
    if (result /= 1) error stop "Test case 5 failed"

    ! Test case 6: shift by 31 bits
    n = 2**29 +  3
    x = 31
    result = shifta(n, x)
    print *, "Test case 6: shifta(", n, ",", x, ") = ", result
    if (result /= 0) error stop "Test case 6 failed"

end program shifta_01