import numpy as np
import matplotlib.pyplot as plt
from matplotlib.colors import ListedColormap


def generate_qr_svg_from_bitstring(bitstring, output_filename="qr_code.svg", 
                                   size=None):
    """
    Generate QR code SVG image from bit string
    
    Args:
        bitstring (str): Bit string (e.g., "101010...")
        output_filename (str): Output filename
        size (int): QR code size (auto-calculated if None)
    """
    
    # Convert bit string to list
    bits = list(bitstring)
    
    # Auto-calculate if size not specified
    if size is None:
        size = int(np.sqrt(len(bits)))
        if size * size != len(bits):
            raise ValueError(f"Bit string length {len(bits)} is not a perfect square")
    
    # Convert bit string to 2D array
    qr_matrix = np.array(bits).reshape(size, size)
    
    # Convert to numeric ('0' to 0, '1' to 1)
    qr_matrix = qr_matrix.astype(int)
    
    # Create figure
    plt.figure(figsize=(12, 12))
    
    # Define colormap (white and black)
    cmap = ListedColormap(['white', 'black'])
    
    # Display QR code (without quiet zone)
    plt.imshow(qr_matrix, cmap=cmap, interpolation='nearest', extent=[0, size, 0, size])
    plt.axis('off')  # Hide axes
    
    # Completely remove margins
    plt.subplots_adjust(left=0, right=1, top=1, bottom=0, wspace=0, hspace=0)
    
    # Save as SVG file (high resolution)
    plt.savefig(output_filename, format='svg', bbox_inches='tight', dpi=600, 
                pad_inches=0)
    plt.close()
    
    print(f"QR code saved to {output_filename}")


def generate_qr_svg_with_highlight(bitstring, highlight_positions=None, 
                                   output_filename="qr_code_highlighted.svg", 
                                   size=None):
    """
    ビット文字列からQRコードのSVG画像を生成し、特定の位置をハイライトする
    
    Args:
        bitstring (str): ビット文字列
        highlight_positions (list): ハイライトする位置のリスト [(row, col), ...]
        output_filename (str): 出力ファイル名
        size (int): QRコードのサイズ
    """
    
    # Convert bit string to list
    bits = list(bitstring)
    
    # Auto-calculate if size not specified
    if size is None:
        size = int(np.sqrt(len(bits)))
        if size * size != len(bits):
            raise ValueError(f"Bit string length {len(bits)} is not a perfect square")
    
    # Convert bit string to 2D array
    qr_matrix = np.array(bits).reshape(size, size)
    
    # Convert to numeric ('0' to 0, '1' to 1)
    qr_matrix = qr_matrix.astype(int)
    
    if highlight_positions:
        highlight_matrix = np.zeros((size, size), dtype=int)
        for row, col in highlight_positions:
            if 0 <= row < size and 0 <= col < size:
    
    # Create figure
    plt.figure(figsize=(12, 12))
    
    if highlight_positions:
        cmap = ListedColormap(['white', 'black', 'red'])
        display_matrix = np.where(highlight_matrix == 2, 2, qr_matrix)
    else:
        cmap = ListedColormap(['white', 'black'])
        display_matrix = qr_matrix
    
    # Display QR code (without quiet zone)
    plt.imshow(display_matrix, cmap=cmap, interpolation='nearest', 
               extent=[0, size, 0, size])
    plt.axis('off')  # Hide axes
    
    # Completely remove margins
    plt.subplots_adjust(left=0, right=1, top=1, bottom=0, wspace=0, hspace=0)
    
    # Save as SVG file (high resolution)
    plt.savefig(output_filename, format='svg', bbox_inches='tight', dpi=600, 
                pad_inches=0)
    plt.close()
    
    print(f"ハイライト付きQRコードを {output_filename} に保存しました")


if __name__ == "__main__":
    # test_bitstring = '1111111001001100110010111111110000010001110111011101000001101110101110111011101010111011011101001110111011100101110110111010001000100010001011101100000100100010001000010000011111111010101010101010111111100000000111011101110100000000111011111011001100110110001000110100100110011001100010011101101010010001000100010110111101011001001000100010111010001100011100001000100011001001000100001100111011101110010111010110101011101110111010000111111000000001110111010001000101000110010100110011001110001000111001001001100110001010111010111000100100010001011101101001101101100010001011100000101010100100100010001111100000000000011011101110110001101111111110110110111010101011011100000101010111011101000110011011101010010011001111111011110111010011100110011101101010101110101110010001010011001011000001010110001000001011101011111110111010001000111100111'
    # test_bitstring = '1111111001001100110010111111110000010001110111011101000001101110101110110011101010111011011101001110111011000101110110111010001000100010001011101100000100100010001000010000011111111010101010101010111111100000000101010101110100000000111011111011001101110110001000110100100110011001100010011101101010010001000100010110111111111001001100100010110000001100011100001000100011001101000101001100111001101110010111010110101011101110111010000111111000000001110111010001000101000110010100111011011110001001111001001001100110001010111010111000100100011001011101101001101101100010001011100000101010100100100010001111100000000000011011101110110001101111111110110110111010101011011100000101010111011101000110011011101010010011001111111011110111010011100110011101101010101110101100010001010111001011000001010110001100001011101011111110111010001000111100111'
    
    # test_bitstring = '1111111000100010001000111111110000010010001000100001000001101110101001000100010010111011011101001001100110010101110110111010010011001100101011101100000100011101110111010000011111111010101010101010111111100000000100100010001000000000111011111000100010001110001000110000001011101110111010101100010011001110111011101101111100111000110111011101100010011110111110110011001100100001101011000001100110011010000101010010110100010001000100011110001100010010001000101110000001010010010010001000110100001000110001001110111011100001111001111111011011101110110011101111100101011101110100010001100111100101001100111111100000000000011110011001010001101111111110111001000100101011111100000101011000100011000100101011101010001000100011111001010111010001111011100010111010101110101111101110101111100011000001010101110111100111101011111110100100110011000100011'
    # test_bitstring = '1111111000100010001000111111110000010010001000101001000001101110101001000100010010111011011101001001100110010101110110111010010011001100101011101100000100011101110111010000011111111010101010101010111111100000000100100010001000000000110011111000100010001110000000110000001011101110111010101100010011000110111011101101111100111000110111011101100110011110111110110011001100100001101001000001100110011010000101010010110100010001000100011110001100010010001000101110000001010010010010001000110100101000110001001110111111100001111011111111011010111110110011101111100101011101110100010001100111100101001000111111100000000000011110011001010001101111111110111001000001101011110100000101011000100011000100101011101011001000100011111011010111010001111011110010111010101110101111101110101111100011000001010111111111100111101011111110100100110011000100011'
    
    # test_bitstring = '1111111000100010001000111111110000010010001000100001000001101110101001000100010010111011011101001001100110010101110110111010010011001100101011101100000100011101110111010000011111111010101010101010111111100000000100100010001000000000111011111000100010001110001000000000011011101110111001011100001111001110111011101001011111000000110111011101000100011011001010110011001100101000111000100011100110011000100011100000100100010001000100101110010100100010001000101110001100111011101010001000110010001011101011001110111011101000011000011101011011101110111111101000101000011101110100011000100100100001001100111111100010000000011010011001010001010111111110100001000100101010011100000101001000100011000100111011101011101000100011111000010111010011111011100010111010101110101011101110101111110011000001010001110111100101001011111110110100110011000100011'
    # test_bitstring = '1111111000100010001000111111110000010010001000100001000001101110101001000100010010111011011101001001100110010101110110111010010011001100101011101100000100011101110111010000011111111010101010101010111111100000000100100000001000000000111011111000100010001110001000000000011011101110111001011100001111101110111111101001011101000000110111011101000100010011101010110011001100101000111010100011100110011010100011100000100100010001000100101110010100100010001000101110001100111011101010001000110010001011101011000100111011101000011000011100011011101110111111101000101010011100110100011000100100100001001100111111100010000000011010011001010001010111111110100001000100101010011100000101001000000011000100111011101011101000100011111000010111010001111011100010111010101110101011101110101111110011000001000001100111101101001011111110010100110010000100011'
    
    # aaai.org
    # test_bitstring = '1111111000100010001000111111110000010010001000100001000001101110101001000100010010111011011101001001100110010101110110111010010011001100101011101100000100011101110111010000011111111010101010101010111111100000000100100010001000000000111011111000100010001110001001001100011011101110111001111111101111101110111011101001111011001001110111011101000110000100101100110011001100111000110011000111100110011000100111010000101100010001000101100111100000011010001000101110000000100011111010001000110010001000001011101110111011100101111000011111011011101110100101101101100011011101110100010000101000100011001100111111110010000000010010011001010001101111111110100001000100101010011100000101111000100011000100101011101011101000100011111000010111010010111011100010100010101110101011101110101110110011000001011101110111100110101011111110101100110011000010111'
    test_bitstring = '1111111010100010001000111111110000010010001000100001000001101110101000000100010010111011011101001001100110010101110110111010010011011000101011101100000100011101100111010000011111111010101010101010111111100000000100100010001100000000111011111000110010001010001001001110011011101110111001111111101111101110111011101001111011001001110111011101000110000100101100110011001100111000110011100111100100011000100111010000111100010001000101100111100000011010001000101110000000100011111010001000110010001000001011101110111001100100111100011111011011101010100101101101100011011101110100010000111000100010001100111111110010000000010010011001010001101111111110100001000100101010011100000101111000100011000100101011101011101000100011111000010111010000111011100010100010101110101011101110101110110011000001011101110111100110101011111110101100110011000010101'
    
    generate_qr_svg_from_bitstring(test_bitstring, "aaai_corr.svg")
    
    # generate_qr_svg_with_highlight(test_bitstring, highlight_positions, 
    #                                "test_qr_highlighted.svg") 