【C语言基础】C语言实现矩阵相乘
前言
最近在考虑如何实现kalman跟踪,其中涉及较多矩阵运算,比如矩阵相乘、矩阵转置等,先实现了一个矩阵相乘的c代码如下。其实,后续可以使用matrix类实现kalman跟踪。
code

#include "stdio.h" void Multi(int * left, int * right, int * result, int f1, int f2, int s1, int s2); int main() { int i, j; int a[4][3] = { {1,2,3}, {4,5,6}, {7,8,9}, {1,2,3}}; int b[3][3] = { { 1,2,3 }, { 4,5,6 }, {7,8,9} }; //c矩阵为a矩阵与b矩阵的乘积 int c[4][3]; //计算两个矩阵相乘 Multi(a[0], b[0],c[0], 4, 3, 3, 3); //输出c矩阵 for (i = 0; i < 4; i++) { for(j=0;j<3;j++) printf("%4d ", c[i][j]); printf("\n"); } //system("pause"); return 0; } //矩阵相乘算法,最后四个参数是两个相乘的矩阵的行数和列数 void Multi(int * left, int * right, int * result,int f1, int f2, int s1, int s2) { //int a[f1][f2], b[s1][s2], c[f1][s2]; //a[i][j]==a[i*f2+j] //由矩阵相乘,要求f2=s1,以下用f2 for (int i = 0; i < f1; i++) //i表示第i行 { for (int j = 0; j < s2; j++) //j表示第j列 { result[i*f2 + j] = 0; //在这里 result[i][j] = result[i*f2+j]; for(int p=0;p<f2;p++) { result[i*f2 + j] +=left[i*f2+p]*right[p*f2+j]; } } } }
参考
1. 矩阵相乘;
2. github_ikalman;
完
各美其美,美美与共,不和他人作比较,不对他人有期待,不批判他人,不钻牛角尖。
心正意诚,做自己该做的事情,做自己喜欢做的事情,安静做一枚有思想的技术媛。
版权声明,转载请注明出处:https://www.cnblogs.com/happyamyhope/
心正意诚,做自己该做的事情,做自己喜欢做的事情,安静做一枚有思想的技术媛。
版权声明,转载请注明出处:https://www.cnblogs.com/happyamyhope/
分类:
c/c++
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
2019-11-29 【python库模块】Python subprocess模块功能与常见用法实例详解
2019-11-29 【软件工具】ImageMagick
2019-11-29 【linux基础】如何配置ubuntu系统为静态IP地址
2018-11-29 Vim使用笔记
2018-11-29 multi-thread debug