import segno
import numpy as np
from utils import random_replace_alphanum_np

def count_bit_diff(array1, array2):
    array1 = np.asarray(array1, dtype=int)
    array2 = np.asarray(array2, dtype=int)
    return np.count_nonzero(array1 ^ array2)

for version in [3]:
    for error_correction in ["L"]:
        box_size = 1
        border=0
        mask_pattern = 0

        data_list = [
            "example.com",
            # "google.com",
            # "yahoo.co.jp",
            # "amazon.co.jp",
            # "rakuten.co.jp",
            # "twitter.com",
            # "facebook.com",
            # "instagram.com",
            # "linkedin.com",
            # "github.com",
        ]

        average_bit_diff = []

        for i in range(len(data_list)):
            data = data_list[i]
            replaced_data = [data]
            for i in range(1000):
                replaced = random_replace_alphanum_np(data, 1)
                replaced_data.append(replaced)
                
            encoded_data = []

            for i in replaced_data:
                qr = segno.make(i, 
                                version=version, 
                                error=error_correction, 
                                mask=mask_pattern, 
                                micro=None,
                                boost_error=False)
                
                data_binary = np.array(qr.matrix, dtype=int).astype(int).flatten()
                encoded_data.append(data_binary)

            ref_bit = encoded_data[0]
            othor_bits = encoded_data[1:]

            diff_counts = [count_bit_diff(ref_bit, other) for other in othor_bits]
            average_diff = np.mean(diff_counts)
            average_bit_diff.append(average_diff)
            
            print(diff_counts)
            
        print(version, error_correction, np.mean(average_bit_diff))
    
