import numpy as np


def make_grid(
    images,
    nrow=8,
    padding=2,
    col_padding=0,  # Padding between first and second columns
    normalize=False,
    interval=None,
    scale_each=False,
    pad_value=0.0,
):
    """
    Create a grid of images from a batch of NumPy arrays.

    Args:
        images (numpy.ndarray): Batch of images with shape (num_images, height, width, channels).
        nrow (int, optional): Number of images displayed in each row of the grid. Default is 8.
        padding (int, optional): Padding between the images. Default is 2.
        col_padding (int, optional): Additional padding specifically between the first and second columns. Default is 0.
        normalize (bool, optional): If True, normalize the input images to the range [0, 1]. Default is False.
        interval (tuple, optional): Tuple (min, max) specifying the range of values for normalization. Default is None.
        scale_each (bool, optional): If True, scale each image individually. Default is False.
        pad_value (float, optional): Value for the padded pixels. Default is 0.

    Returns:
        numpy.ndarray: A NumPy array representing the grid of images.
    """
    if normalize:
        if interval is not None:
            images = np.clip(images, interval[0], interval[1])
        images = (images - images.min()) / (images.max() - images.min())

    if scale_each:
        images = images - images.min(axis=(1, 2, 3), keepdims=True)
        images = images / (images.max(axis=(1, 2, 3), keepdims=True) + 1e-6)

    num_images, height, width, channels = images.shape

    # Calculate the number of rows needed
    nrow = min(nrow, num_images)
    ncol = (num_images + nrow - 1) // nrow

    # Calculate the size of the output grid
    # Account for special padding between the first and second columns
    grid_height = nrow * height + (nrow - 1) * padding
    grid_width = ncol * width + (ncol - 1) * padding

    # Adjust for the extra padding between the first and second columns
    if ncol > 1:
        grid_width += col_padding

    # Create an empty grid
    grid = np.full((grid_height, grid_width, channels), pad_value, dtype=images.dtype)

    for i in range(num_images):
        row = i // ncol
        col = i % ncol

        y_start = row * (height + padding)
        x_start = col * (width + padding)

        # Adjust x_start if it's the second column (col == 1) to add extra padding
        if col >= 1:
            x_start += col_padding

        grid[y_start : y_start + height, x_start : x_start + width, :] = images[i]

    return grid
