import matplotlib.pyplot as plt

def draw_grid_with_arrow(pattern_num, coords, filename):
    plt.figure(figsize=(6, 6))


    for i in range(3):
        for j in range(3):
            plot_i = 2 - i

                facecolor = START_COLOR
                facecolor = GOAL_COLOR
            else:
                facecolor = 'white'

            plt.fill(
                [j, j+1, j+1, j],
                [plot_i, plot_i, plot_i+1, plot_i+1],
                facecolor=facecolor,
                edgecolor='black',
            )

    x_coords = []
    y_coords = []
    for i, j in coords:

    for i in range(len(x_coords) - 1):
        if i == len(x_coords) - 2:
            dx = x_coords[i+1] - x_coords[i]
            dy = y_coords[i+1] - y_coords[i]
            length = (dx**2 + dy**2)**0.5
            if length > 0:
                dx = dx / length * 0.2
                dy = dy / length * 0.2
            plt.plot(
                [x_coords[i], x_coords[i+1] - dx],
                [y_coords[i], y_coords[i+1] - dy],
                color=ARROW_COLOR,
                linewidth=3
            )
            plt.arrow(
                x_coords[i+1] - dx,
                y_coords[i+1] - dy,
                dx,
                dy,
                head_width=0.2,
                head_length=0.2,
                fc=ARROW_COLOR,
                ec=ARROW_COLOR,
                length_includes_head=True,
            )
        else:
            plt.plot(
                [x_coords[i], x_coords[i+1]],
                [y_coords[i], y_coords[i+1]],
                color=ARROW_COLOR,
                linewidth=3
            )

    plt.savefig(filename, bbox_inches='tight', format='svg')
    plt.close()

pattern1 = [
    (0, 0), (0, 1), (0, 2),
    (1, 0), (1, 1), (1, 2),
    (2, 0), (2, 1), (2, 2)
]

pattern2 = [
    (0, 2), (0, 1), (0, 0),
    (1, 2), (1, 1), (1, 0),
    (2, 2), (2, 1), (2, 0)
]

pattern3 = [
    (2, 0), (1, 0), (0, 0),
    (2, 1), (1, 1), (0, 1),
    (2, 2), (1, 2), (0, 2)
]

pattern4 = [
    (2, 2), (1, 2), (0, 2),
    (2, 1), (1, 1), (0, 1),
    (2, 0), (1, 0), (0, 0)
]

draw_grid_with_arrow(1, pattern1, 'order_fig_pattern1.svg')
draw_grid_with_arrow(2, pattern2, 'order_fig_pattern2.svg')
draw_grid_with_arrow(3, pattern3, 'order_fig_pattern3.svg')
draw_grid_with_arrow(4, pattern4, 'order_fig_pattern4.svg')
