Используя ctypes в python, я могу свободно передавать массив в функцию C, используя указатель на свой первый элемент, поскольку массив распадается до указателя на свой первый элемент в C. Итак, для сигнатуры функции C
void insert_sort(int A[], size_t length);
я могу реализовать следующую python оболочку.
import ctypes
from typing import List, Callable
def wrap_function(lib: ctypes.CDLL, name: str, restype: object, argtypes: List[object]) -> Callable:
"""Simplify wrapping ctypes functions"""
func = lib.__getattr__(name)
func.restype = restype
func.argtypes = argtypes
return func
lib = ctypes.CDLL("path/to/library.so")
insert_sort = wrap_function(lib, 'insert_sort', None, [ctypes.POINTER(ctypes.c_int), ctypes.c_size_t])
Но C также позволяет иметь массивы массивов и еще массивы массивов переменного размера. Например, подпись функции C ниже демонстрирует это.
void matrix_multiply(size_t n, int A[n][n], int B[n][n], int C[n][n]);
Как бы обернуть эту функцию? Чтобы систематизировать мой вопрос, что находится в пустом поле ниже?
matrix_multiply = wrap_function(lib, 'matrix_multiply', None, [...What goes here...])
Если бы размер массивов был известен, мы могли бы просто написать
matrix_multiply = wrap_function(lib, 'matrix_multiply', None, [
ctypes.c_size_t, ((ctypes.c_int * 4)*4), ((ctypes.c_int * 4)*4), ((ctypes.c_int * 4)*4)
])
для массивов размера 4. Но что может делаем когда это число неизвестно?