d的矩阵类

import std;

struct Matrix(size_t X, size_t Y = X)
{
    enum x_length = X; // 编译时可用
    enum y_length = Y;
    double[X * Y] data;

    // 重载操作符
    Matrix opBinary(string op)(Matrix rhs)
    {
        static if (op == "*")
        {
            // 用*
            static if (X == 2)
            {
                return Matrix();
            }
            else
                static assert("不支持");
        }
        else
            static assert(0, "未实现" ~ op ~ "操作符");
    }
}

void main()
{
    // 按值检查
    auto a = Matrix!(2)();
    a.data = 0;
    auto b = Matrix!(2)();
    b.data = 0;

    writeln("一样吗?", a == b); // 按值检查

    auto m = Matrix!(2)();
    m.data = [1.0, 0.0, 0.0, 1.0];
    auto n = Matrix!(2)();
    n.data = [2.0, 3.0, 4.0, 5.0];

    // 可用*符号
    auto u = m * n;

    writeln("u.data对比n.data:");

    for (int i = 0; i < u.data.length; ++i)
        writeln(u.data[i], "\t", n.data[i]);
}
posted @   zjh6  阅读(15)  评论(0编辑  收藏  举报  
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示