function [B, C, D1, D2] = split_logical_tensor(A, D, ratio)
    % 输入:
    %   A: logical 类型的张量
    %   D: 与 A 形状一致的数值张量，通常 D = A .* rand(...)
    %   ratio: 比例（如 0.7 表示 70% 分到 B，30% 分到 C）
    %
    % 输出:
    %   B, C: logical 张量，B | C == A，且 B & C == 0
    %   D1, D2: 数值张量，D1 只在 B 的位置非零，D2 只在 C 的位置非零，D = D1 + D2

    if ~islogical(A)
        error('A 必须是 logical 类型');
    end
    if ~isequal(size(A), size(D))
        error('A 和 D 的大小必须一致');
    end
    if ratio < 0 || ratio > 1
        error('ratio 必须在 [0, 1] 范围内');
    end

    % 找到 A 中为 true 的线性索引
    idx = find(A);
    n = numel(idx);

    % 随机打乱这些索引
    perm = randperm(n);
    nB = round(ratio * n);

    % 分配给 B 和 C
    idxB = idx(perm(1:nB));
    idxC = idx(perm(nB+1:end));

    % 初始化 B 和 C
    B = false(size(A));
    C = false(size(A));
    B(idxB) = true;
    C(idxC) = true;

    % 检查是否满足 A == B | C
    assert(isequal(A, B | C), 'A ≠ B | C');
    assert(isempty(find(B & C, 1)), 'B 和 C 有重叠');

    % 构造 D1 和 D2
    D1 = zeros(size(D));
    D2 = zeros(size(D));
    D1(B) = D(B);
    D2(C) = D(C);

    % 检查 D 是否等于 D1 + D2（只在 A 为 1 的位置上检查）
    assert(norm(D(A) - (D1(A) + D2(A)), 'fro') < 1e-12, 'D ≠ D1 + D2');

end
