-# Prumerna delka slova
-if mod_m:
- analyza.append("\nPrumerna delka slova:")
- slova = ocesat(zprava, True).split()
- analyza.append('{0:.3}'.format(float(sum([len(word) for word in slova]))/len(slova)))
-
-# Frekvence znaku
-analyza.append("\nFrekvencni analyza:")
-freq = dict()
-for char in ABECEDA:
- freq[char] = 0
-for char in zprava:
- if char in freq:
- freq[char] += 1
-celkem = sum(freq.values())
-for char in sorted(freq, key=freq.get, reverse=True):
- analyza.append('{0} {1:>3} {2:>6.2%}'.format(char, freq[char],
- float(freq[char])/celkem))
-
-# Index koincidence
-# TODO verze s mezerami
-analyza.append("\nIndexy koincidence (vzdy bez mezer):")
-analyza.append(koincidence.tabulka_indexu(zprava))
-
-# Jakobsen
-# TODO verze bez mezer
-if mod_m:
- analyza.append("\nJakobsen (s mezerami):")
- analyza.append(jakobsen.desifruj(zprava, './ref'))
-if mod_x:
- analyza.append("\nJakobsen (bez mezer):")
- analyza.append(jakobsen.desifruj(zprava, './bref'))
-
-# Posuny v abecede
-# TODO najit nejvhodnejsi posuny a vypsat jenom ty
-def posun(char):
- if 65 <= ord(char) < 90:
- return chr(ord(char) + 1)
- if ord(char) == 90:
- return 'A'
- else:
- return char
-
-if 'P' in opsny or 'A' in opsny:
- analyza.append("\nPosuny v abecede:")
- posunuty = zprava
- for i in range(26):
- posunuty = map(posun, posunuty)
- analyza.append(''.join(posunuty))
-
-# Bigramy
-if ('B' in opsny or 'A' in opsny):
- analyza.append("\nBigramy podle cetnosti:")
- bigramy = dict()
- for i in ABECEDA:
- for j in ABECEDA:
- bigramy[i+j] = 0
- for i in range(0, len(zprava)-1):
- if zprava[i:i+2] in bigramy:
- bigramy[zprava[i:i+2]] += 1
- celkem = sum(bigramy.values())
- for char in sorted(bigramy, key=bigramy.get, reverse=True):
- if bigramy[char] == 0:
- break
- analyza.append('{0} {1:>3} {2:>6.2%}'.format(char, bigramy[char],
- float(bigramy[char])/celkem))
-
-# Podpis a pozdrav
-analyza.append(''.join(["\nS pozdravem\nVas Robot\n"
- "\n--\nPro napovedu zaslete mail s predmetem \"",
- settings.subject," H\".\n"]))
-
-# Kompozice odpovedi
-msg = MIMEText("\n".join(analyza))
-msg['Subject'] = "Analyza Vasi zpravy"
-msg['From'] = settings.name + " <" + settings.mail + ">"
-msg['To'] = odesilatel