Skip to content
Snippets Groups Projects
modules-matrix.py 2.25 KiB
Newer Older
  • Learn to ignore specific revisions
  • # -*- coding: utf-8 -*-
    
    import collections
    
    Lukáš Krupčík's avatar
    Lukáš Krupčík committed
    import itertools
    import re
    
    
    from distutils.version import LooseVersion
    
    
    def get_data(filename):
        '''function to read the data form the input csv file to use in the analysis'''
        reader = [] # Just in case the file open fails
        with open(filename, 'rb') as f:
    
    Lukáš Krupčík's avatar
    Lukáš Krupčík committed
            reader = csv.reader(f,delimiter=',')
    
            #returns all the data from the csv file in list form
            #f.close() # May need to close the file when done
            return list(reader)  # only return the reader when you have finished.
    
    your_list = []
    
    Lukáš Krupčík's avatar
    Lukáš Krupčík committed
    your_list += get_data('./scripts/anselm.csv')
    your_list += get_data('./scripts/salomon.csv')
    your_list += get_data('./scripts/uv2000.csv')
    
    Lukáš Krupčík's avatar
    Lukáš Krupčík committed
    your_list += get_data('./scripts/phi.csv')
    your_list += get_data('./scripts/new.csv')
    
    
    counts = dict()
    for i in your_list:
    
    Lukáš Krupčík's avatar
    Lukáš Krupčík committed
      #print i[0]
      #print int(i[1])
    
      counts[i[0]]=counts.get(i[0], 0) + int(i[1])
    
    
    Lukáš Krupčík's avatar
    Lukáš Krupčík committed
    l = ['A', 'S', 'U', 'P', 'N']
    
    Lukáš Krupčík's avatar
    Lukáš Krupčík committed
    c = []
    
    Lukáš Krupčík's avatar
    Lukáš Krupčík committed
    mask = ''.join(reversed(l))
    
    Lukáš Krupčík's avatar
    Lukáš Krupčík committed
    from itertools import product
    for bits in product([0, 1], repeat=len(l)):
        s = "".join(str(bit) for bit in bits)
        ns = ""
        for i in range(len(s)):
            if s[i] == "1":
                ns += mask[i]
            else:
                ns += "-"
        c.append(ns)
    
    print '!!! Hint "Cluster Acronyms"'
    
    Lukáš Krupčík's avatar
    Lukáš Krupčík committed
    print '    A - Anselm • S - Salomon • U - UV2000 at Salomon • P - Intel Xeon Phi cards at Salomon • N - new cluster'
    
    David Hrbáč's avatar
    David Hrbáč committed
    print '| Module </br><input id="searchInput" placeholder="🔍 Filter" style="width: 8rem; border-radius: 0.2rem; color: black; padding-left: .2rem;"> | Versions | Clusters |'
    
    David Hrbáč's avatar
    David Hrbáč committed
    print "| ------ | -------- | -------- |"
    
    David Hrbáč's avatar
    David Hrbáč committed
    software = dict()
    versions = ''
    clusters = ''
    prev = ''
    
    
    for m,i in sorted(counts.items()):
    
    Lukáš Krupčík's avatar
    Lukáš Krupčík committed
    #  print m
    
    David Hrbáč's avatar
    David Hrbáč committed
      split =  m.split('/')
    
    Lukáš Krupčík's avatar
    Lukáš Krupčík committed
    #  print split
    
    David Hrbáč's avatar
    David Hrbáč committed
      if len(split) > 1:
        a = split[0]
        b = split[1]
        if split[0] <> prev:
          software[a] = {}
    
        software[a][b] = '`' + c[i] + '`'
    
    David Hrbáč's avatar
    David Hrbáč committed
        prev = a
    
    for m in sorted(software.items(), key=lambda i: i[0].lower()):
    
    David Hrbáč's avatar
    David Hrbáč committed
      software = m[0]
    
      versions = []
      clusters = []
      for key in sorted(m[1], key=LooseVersion ):
        versions.append(key)
        clusters.append(m[1][key])
      print "| %s | %s | %s |" % (software, '</br>'.join(versions), '</br>'.join(clusters))
    
    
    print
    print '---8<--- "modules_matrix_search.md"'