Labfans是一个针对大学生、工程师和科研工作者的技术社区。 论坛首页 | 联系我们(Contact Us)
MATLAB爱好者论坛-LabFans.com
返回   MATLAB爱好者论坛-LabFans.com > 其它 > 资料存档
资料存档 资料存档
回复
 
主题工具 显示模式
旧 2019-12-10, 20:48   #1
poster
高级会员
 
注册日期: 2019-11-21
帖子: 3,006
声望力: 66
poster 正向着好的方向发展
帖子 如何在MATLAB中轻松形成Levi-Civita 3x3x3矩阵?

我特别想知道如何在不使用for循环的情况下创建它。另外,如何对一般的N维Levi-Civita矩阵进行处理



回答:

好吧,我很无聊,所以我走了一条弯曲的路。它不能回答问题,因为这不是“容易的”,但是因为我很开心,所以我正在分享这个问题。

根据维基百科的定义,您可以构建一个函数,以从索引中为您提供Cevi-Levita符号的值:

LC_value = @(v) round(prod(prod(triu(repmat(v,[numel(v) 1])-repmat(v',[1 numel(v)]),1) ... ./repmat(factorial([1:numel(v)]'),[1 numel(v)])+tril(ones(numel(v)))))); 这将实现常规的n维嵌套产品定义。注意,阶乘函数可能会导致高维问题。这里有round函数,因为您正在执行浮点运算以生成整数。

下一步是将此功能应用于所有可能的索引组合。不过,将其仅应用于[1 2 3]的排列会更快。

sites = perms([1 2 3]); values = arrayfun(@(i)LC_value(sites(i,:)),(1:size(sites,1))'); lcMat = zeros(3,3,3); lcMat(sub2ind(size(lcMat),sites(:,1),sites(:,2),sites(:,3))) = values; 而已。它适用于三个维度,并且应该适用于更高的维度,尽管我尚未对其进行测试。



更多&回答...
poster 当前离线   回复时引用此帖
回复


发帖规则
不可以发表新主题
不可以发表回复
不可以上传附件
不可以编辑自己的帖子

启用 BB 代码
论坛禁用 表情符号
论坛启用 [IMG] 代码
论坛启用 HTML 代码



所有时间均为北京时间。现在的时间是 01:22


Powered by vBulletin
版权所有 ©2000 - 2025,Jelsoft Enterprises Ltd.