File: mkswapbits.rb

package info (click to toggle)
genometools 1.6.1%2Bds-3
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 50,412 kB
  • sloc: ansic: 271,241; ruby: 30,339; python: 4,880; sh: 3,193; makefile: 1,194; perl: 219; pascal: 159; haskell: 37; sed: 5
file content (59 lines) | stat: -rwxr-xr-x 1,220 bytes parent folder | download | duplicates (9)
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
#!/usr/bin/env ruby

def mkswapbitpairs(i,j)
  if i <= j
    STDERR.puts "assertion i=#{i}>#{j}=j failed"
    exit 1
  end
  return "GT_SWAPBITPAIRS(kmer,#{2*i},#{2*j},#{2*(i-j)})"
end

def extractpair(i)
  return "(kmer & (3U << #{2*i}))"
end

def mkswapbits(len)
  i=len-1
  j=0
  explist=[]
  loop do 
    if i < j
      break
    end
    if i == j
      explist.push(extractpair(i))
      break
    end
    explist.push(mkswapbitpairs(i,j))
    i -= 1
    j += 1
  end
  return explist.join(" |\n"+" "*13)
end

if ARGV.length != 0
  STDERR.puts "Usage: #{$0}"
  exit 1
end

puts "#include <stdio.h>"
puts "#include \"assert_api.h\""
puts "#define GT_SWAPBITPAIRS(KMER,L1,L2,D) (((KMER) & (3UL << L1)) >> D) |\\"
puts "                                      (((KMER) & (3UL << L2)) << D)"

puts "static GtCodetype gt_kmercode_reverse(GtCodetype kmer,unsigned int kmersize)"
puts "{"
puts "  switch (kmersize)"
puts "  {"
2.upto(32) do |len|
  if len == 16
    puts "#ifdef _LP64"
  end
  puts "    case #{len}:"
  puts "      return #{mkswapbits(len)};"
end
puts "#endif"
puts "    default: fprintf(stderr,\"illegal kmersize=%u\\n\",kmersize);"
puts "             exit(GT_EXIT_PROGRAMMING_ERROR);"
puts "  }"
puts "}"