Skip to content

Hamilton2718/linear_algebrea_calculator

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

19 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

algebra

硬件技术团队编程基础作业

预修要求|Requirements

修读过《C程序设计基础》、《线性代数》以及X·Lab硬件技术团队第一次内训或其对应的高阶课程。

说明|Explainations

本题目的难度对于初学者而言相对较高,主要考察了基础的数学能力、通过编程解决问题的能力以及工程管理、CMake、git等综合能力。该作业的最终得分仅作参考,同学们可根据自己的能力来决定实现哪些函数。

题目背景|Background

《线性代数》作为浙江大学工科多数专业必修的数学基础课程,对于其掌握是至关重要的,后续各大专业的专业课程也都离不开线性代数。然而,在后续的专业课程学习中,我们往往只需要计算一些矩阵的数值解,这个过程如果用手去计算的话是十分痛苦的。秉承着“我都学编程了就不要自己做一些无意义的事情”的原则,我们决定实现一个线性代数计算库,来辅助我们进行运算。

当然,如MATLAB、Python等高级编程语言已经可以做到这类事情,且做得更好,但这并不妨碍我们通过这样一种方式来锻炼自己的C语言编程能力。

题目介绍|Introduction

本仓库给出了我们在内训中提到的工程模板,同学们要做的任务如下:

  1. 自学git,注册GitHub账号,将本仓库在自己的GitHub账户下Fork一份(注意是Fork,禁止直接clone本仓库到本地,否则你将无法完成后续提交),并按照yourname_hw1的格式更改仓库名称(在仓库中的Settings处可修改,记得不要用中文,仓库权限为public,如涉及到隐私保护,可设为private,但要将[email protected]这个账户设置为协作者)。
  2. 将你的仓库clone到本地。
  3. 按照内训所讲的工程模板补充所缺的文件夹。
  4. 根据inc/algebra.h中的注释和预定义,在src/algebra.c中实现对应的函数。
  5. 根据内训所讲,自行编写CMakeLists.txt文件,使你的工程能够在本地成功编译运行。
  6. 自学Markdown,修改README.md文件,需要包含你的实现思路(大致描述即可)以及本地运行截图。
  7. 将你的修改提交到远程仓库,并将仓库链接提交(提交方式待定)。

思路参考|Thinking

doc文件夹。

交互格式|Format

在本题目中,main.c文件已给出,不需要同学们自己实现,也请不要更改这个文件,否则可能出现判题错误。

输入格式

本题目采用帧判定的思路进行,每一帧的第一行指令代码,+-*.tdirj分别测试add_matrixsub_matrixmul_matrixscale_matrixtranspose_matrixdet_matrixinv_matrixrank_matrixtrace_matrix函数,q表示退出。

接下来的一行输入矩阵 $\mathbf{A}$ 的行数 $m$ 和列数 $n$ ,在接下来的 $m$ 行中输入 $n$ 个双精度浮点数,以空格分开。 对于二元运算函数的测试,需要再按照上述过程输入矩阵 $\textbf{B}$

可能的一次运行输入如下:

+
2 2
1.1 1.3
2.4 3.7
2 2
3.1 4.3
5.1 7.1
+
2 2
1.1 1.2
2.4 3.5
2 3
1 2 2.1
3 2 3.3
q

输出格式

在每一帧中,依次根据输入的指令代码运行对应的函数,并给出函数的输出与标准值比对。上述输入的正确输出如下:

4.20    5.60    
7.50    10.80
Error: Matrix a and b must have the same rows and cols.

评分标准|Standard

  • 成功运行:+25分
  • add_matrixsub_matrixmul_matrixscale_matrixtranspose_matrixtrace_matrix功能正常每个+5分
  • det_matrixinv_matrixrank_matrix功能正常每个+15分

为了保证题目难度,每个函数具体的评分标准不予公布。

提交方式|Submit

将你完成任务的GitHub仓库链接通过飞书发送给X-Check机器人,机器人会自动进行打分并将分数返回。参考如下视频:

https://tannin-1316822731.cos.ap-nanjing.myqcloud.com/2024-03-29-827_1711724348.mp4

截止日期|Deadline

待定

解题思路 | Solution

  1. 矩阵的加、减、数乘、矩阵乘法、转置、迹的运算不多赘述;
  2. 矩阵的行列式是通过将第一行展开来求,即遍历第一行元素,求出各自与各自的代数余子式乘积后加和得到;
  3. 矩阵求逆通过公式$ A^{-1}=\frac{A^{}}{\left |A \right |}$求解,难点在于求$ A^{}$。可先通过二重循环遍历矩阵中每个元素,再通过二重循环遍历他们的余子式,当指标与元素行列索引相同时continue即可;
  4. 矩阵求秩通过高斯消元法。大的思路就是通过沿着对角线上元素(即行列索引相同的元素,我们姑且称为主元)进行行与行的倍加消去。如果主元为0,则可遍历以主元为左上角元素的子矩阵中是否还有非0元素,有则通过行列变换换到对角线上,无则return当前rank值,接续循环,直至主元遍历完成或子矩阵为全0矩阵。

About

硬件技术团队编程基础作业

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 41.8%
  • C++ 25.0%
  • Makefile 18.1%
  • CMake 15.0%
  • TypeScript 0.1%