import pandas as pd
import random
import string

# Levenshtein distance and normalized similarity functions omitted

# Function definitions for priority string and similarity generation
def levenshtein_distance(a: str, b: str) -> int:
    m, n = len(a), len(b)
    dp = [[0] * (n + 1) for _ in range(m + 1)]
    for i in range(m + 1):
        dp[i][0] = i
    for j in range(n + 1):
        dp[0][j] = j
    for i in range(1, m + 1):
        for j in range(1, n + 1):
            cost = 0 if a[i-1] == b[j-1] else 1
            dp[i][j] = min(dp[i-1][j] + 1, dp[i][j-1] + 1, dp[i-1][j-1] + cost)
    return dp[m][n]

def normalized_similarity(a: str, b: str) -> float:
    dist = levenshtein_distance(a, b)
    max_len = max(len(a), len(b), 1)
    return 1.0 - dist / max_len


original = "Transformer"  # Length 11

# List of target similarities (1.0, 0.9, ..., 0.0)
target_sims = [round(1.0 - 0.1*i, 1) for i in range(11)]

examples = []
length = len(original)

# Create list of lowercase alphabets not included in original string
orig_lower_set = set(original.lower())
available_chars = [c for c in string.ascii_lowercase if c not in orig_lower_set]

for s in target_sims:
    # Calculate required edit distance
    d = int(round((1 - s) * length))
    mutated = list(original)
    # Randomly select d positions and replace
    for idx in random.sample(range(length), d):
        mutated[idx] = random.choice(available_chars)
    mutated = "".join(mutated)
    # Calculate actual similarity
    sim = normalized_similarity(original, mutated)
    examples.append({
        "Target Similarity": s,
        "Levenshtein Distance": levenshtein_distance(original, mutated),
        "Actual Similarity": round(sim, 2),
        "Mutated String": mutated
    })

df = pd.DataFrame(examples)
print(df)

