# version4
class Version4:
    size = 33
    finder_patterns = [
        [(row, col) for row in range(0, 8) for col in range(0, 8)],  # Top-left
        [(row, col) for row in range(0, 8) for col in range(25, 33)],  # Top-right
        [(row, col) for row in range(25, 33) for col in range(0, 8)],  # Bottom-left
    ]
    alignment_pattern = [(row, col) for row in range(24, 28) for col in range(24, 28)]
    horizontal_timing = [(6, col) for col in range(8, 25)]  # Horizontal
    vertical_timing = [(row, 6) for row in range(8, 25)]  # Vertical
    all_coordinates = []
    for pattern in finder_patterns:
        all_coordinates.extend(pattern)
    all_coordinates.extend(alignment_pattern)
    all_coordinates.extend(horizontal_timing)
    all_coordinates.extend(vertical_timing)
    pattern_2d = all_coordinates
    pattern_1d = [
        r * 33 + c for r, c in all_coordinates
    ]
    def convert_1d_to_2d(self, indices):
        return [(index // 33, index % 33) for index in indices]
    def convert_2d_to_1d(self, coordinates):
        return [r * 33 + c for r, c in coordinates]

# version3
# Finder Pattern
class Version3:
    size = 29
    finder_patterns = [
        [(row, col) for row in range(0, 8) for col in range(0, 8)],  # Top-left
    ]
    # Alignment Pattern
    alignment_pattern = [(row, col) for row in range(20, 25) for col in range(20, 25)]
    # Timing Pattern
    # List all coordinates
    all_coordinates = []
    for pattern in finder_patterns:
        all_coordinates.extend(pattern)
    all_coordinates.extend(alignment_pattern)
    all_coordinates.extend(horizontal_timing)
    all_coordinates.extend(vertical_timing)
    # Convert pattern coordinates to 1D
    pattern_2d = all_coordinates
    pattern_1d = pattern_1d_indices = [
        r * 29 + c for r, c in all_coordinates
    ]
    def convert_1d_to_2d(self, indices):
        return [(index // 29, index % 29) for index in indices]
    def convert_2d_to_1d(self, coordinates):
        return [r * 29 + c for r, c in coordinates]

# version2
class Version2:
    size = 25
    # Finder Pattern + Separator Pattern
    finder_patterns = [
        [(row, col) for row in range(0, 8) for col in range(0, 8)],  # Top-left
        [(row, col) for row in range(0, 8) for col in range(17, 25)],  # Top-right
        [(row, col) for row in range(17, 25) for col in range(0, 8)],  # Bottom-left
    ]
    # Alignment Pattern
    alignment_pattern = [(row, col) for row in range(16, 20) for col in range(16, 20)]
    # Timing Pattern
    horizontal_timing = [(6, col) for col in range(7, 18)]  # Horizontal
    vertical_timing = [(row, 6) for row in range(7, 18)]  # Vertical
    # List all coordinates
    all_coordinates = []
    for pattern in finder_patterns:
        all_coordinates.extend(pattern)
    all_coordinates.extend(alignment_pattern)
    all_coordinates.extend(horizontal_timing)
    all_coordinates.extend(vertical_timing)
    # Convert pattern coordinates to 1D
    pattern_2d = all_coordinates
    pattern_1d = [
        r * 25 + c for r, c in all_coordinates  # Version 2 grid size is 25 x 25
    ]
    def convert_1d_to_2d(self, indices):
        return [(index // 25, index % 25) for index in indices]
    def convert_2d_to_1d(self, coordinates):
        return [r * 25 + c for r, c in coordinates]
    
class Version1:
    size = 21
    finder_patterns = [
        [(row, col) for row in range(0, 7) for col in range(0, 7)],  # Top-left
        [(row, col) for row in range(0, 7) for col in range(14, 21)],  # Top-right
        [(row, col) for row in range(14, 21) for col in range(0, 7)],  # Bottom-left
    ]
    alignment_pattern = [(row, col) for row in range(13, 16) for col in range(13, 16)]
    horizontal_timing = [(6, col) for col in range(7, 14)]  # Horizontal
    vertical_timing = [(row, 6) for row in range(7, 14)]  # Vertical
    all_coordinates = []
    for pattern in finder_patterns:
        all_coordinates.extend(pattern)
    all_coordinates.extend(alignment_pattern)
    all_coordinates.extend(horizontal_timing)
    all_coordinates.extend(vertical_timing)
    pattern_2d = all_coordinates
    pattern_1d = [
        r * 21 + c for r, c in all_coordinates
    ]
    def convert_1d_to_2d(self, indices):
        return [(index // 21, index % 21) for index in indices]
    def convert_2d_to_1d(self, coordinates):
        return [r * 21 + c for r, c in coordinates]

    
def version_info(version):
    if version == 1:
        return Version1()
    elif version == 2:
        return Version2()
    elif version == 3:
        return Version3()
    elif version == 4:
        return Version4()
    else:
        raise ValueError(f"version '{version}' is not supported.")
