import numpy as np

def read_obj(filename):
    """
    Load a .obj file and extract vertices, faces, and normals.

    :param filename: Path to the .obj file.
    :return: Tuple containing vertices, faces, and normals.
    """
    vertices = []
    faces = []
    normals = []
    texture = []

    with open(filename, 'r') as file:
        for line in file:
            if line.startswith('v '):
                # Vertex
                parts = line.strip().split()
                vertex = list(map(float, parts[1:4]))
                vertices.append(vertex)
            elif line.startswith('vn '):
                # Normal
                parts = line.strip().split()
                normal = list(map(float, parts[1:4]))
                normals.append(normal)
            elif line.startswith('vt '):
                # texture uv
                parts = line.strip().split()
                texture = list(map(float, parts[1:4]))
                texture.append(texture)
            elif line.startswith('f '):
                # Face
                parts = line.strip().split()
                face = [int(part.split('/')[0]) - 1 for part in parts[1:4]]
                faces.append(face)

    print(f"Number of vertices: {len(vertices)}")
    print(f"Number of faces: {len(faces)}")
    print(f"Number of normals: {len(normals)}")

    return np.array(vertices), np.array(faces)
