c++ valarray 实现矩阵与向量相乘
#include <iostream>
#include <valarray>
template<class T> class Slice_iter {
std::valarray<T>* v;
std::slice s;
size_t curr;
T& ref(size_t i) const {
return (*v)[s.start()+i*s.stride()];
}
public:
Slice_iter(std::valarray<T> *vv, std::slice ss):v(vv),s(ss),curr(0) {}
Slice_iter end() {
Slice_iter t=*this;
t.curr=s.size();
return t;
}
Slice_iter& operator++() {curr++; return *this;}
Slice_iter operator++(int) {Slice_iter t=*this; curr++; return t;}
T& operator[] (size_t i) {return ref(curr=i);}
T& operator* () {return ref(curr);}
size_t size() const {return s.size();}
template<class U>
friend bool operator==(const Slice_iter<U>&, const Slice_iter<U>&);
template<class U>
friend bool operator!=(const Slice_iter<U>&, const Slice_iter<U>&);
template<class U>
friend bool operator<(const Slice_iter<U>&, const Slice_iter<U>&);
};
template<class T> bool operator==(const Slice_iter<T>& p, const Slice_iter<T>& q) {
return p.curr==q.curr && p.s.stride()==q.s.stride() && p.s.start()==q.s.start();
}
template<class T> bool operator!=(const Slice_iter<T>& p, const Slice_iter<T>& q) {
return !(p==q);
}
template<class T> bool operator<(const Slice_iter<T>& p, const Slice_iter<T>& q) {
return p.curr<q.curr && p.s.stride()==q.s.stride() && p.s.start()==q.s.start();
}
class Matrix {
std::valarray<double>* v;
size_t d1, d2;
public:
Matrix(size_t x, size_t y);
Matrix(const Matrix&);
Matrix& operator=(const Matrix&);
~Matrix() {
if(!v)
delete v;
}
size_t size() const {return d1*d2;}
size_t dim1() const {return d1;}
size_t dim2() const {return d2;}
Slice_iter<double> row(size_t i);
Slice_iter<double> column(size_t i);
Slice_iter<double> operator[] (size_t i) {return row(i);}
Matrix& operator*=(double);
std::valarray<double>& array() {return *v;}
};
inline Slice_iter<double> Matrix::row(size_t i) {
return Slice_iter<double>(v, std::slice(i*d2,d2,1));
}
inline Slice_iter<double> Matrix::column(size_t i) {
return Slice_iter<double>(v, std::slice(i, d1, d2));
}
Matrix::Matrix(size_t x, size_t y) {
d1=x;
d2=y;
v=new std::valarray<double> (x*y);
}
double mul(Slice_iter<double> v1, const std::valarray<double>& v2) {
double res=0;
for(int i=0; i<v1.size(); ++i)
res+=v1[i]*v2[i];
return res;
}
std::valarray<double> operator*(Matrix& m, const std::valarray<double>& v) {
std::valarray<double> res(m.dim1());
for(int i=0;i<m.dim1();++i)
res[i]=mul(m.row(i), v);
return res;
}
Matrix& Matrix::operator*=(double d) {
(*v) *= d;
return *this;
}
size_t slice_index(const std::slice& s, size_t i) {
return s.start()+i*s.stride();
}
void print_seq(const std::slice& s) {
for(int i=0;i<s.size(); ++i)
std::cout<<slice_index(s,i)<<" ";
}
int main() {
const double vd[] = {1,2,3,4,5,6,7,8};
std::valarray<double> v(vd, sizeof(vd)/sizeof(vd[0]));
Matrix MyMat(2, 4);
MyMat.array()=v;
std::cout<<"dim1 = "<<MyMat.dim1()<<" ";
std::cout<<"dim2 = "<<MyMat.dim2()<<"\n";
for(size_t i=0;i<MyMat.dim1();++i) {
for(size_t j=0;j<MyMat.dim2();++j) {
std::cout<<MyMat.row(i)[j]<<" ";
}
std::cout<<"\n";
}
std::slice seg(0, 4, 1);
std::valarray<double> bar=v[seg];
for(size_t i=0; i<bar.size(); ++i) {
std::cout<<bar[i]<<" ";
}
std::cout<<"\n";
std::cout<<"The product of MyMat and bar is: \n";
std::valarray<double> res=MyMat*bar;
for(size_t i=0;i<res.size();++i) {
std::cout<<res[i]<<" ";
}
std::cout<<"\n";
return 0;
}
c++ valarray 实现矩阵与向量相乘的更多相关文章
- 学习笔记DL004:标量、向量、矩阵、张量,矩阵、向量相乘,单位矩阵、逆矩阵
线性代数,面向连续数学,非离散数学.<The Matrix Cookbook>,Petersen and Pedersen,2006.Shilov(1977). 标量.向量.矩阵.张量. ...
- Python 矩阵与矩阵以及矩阵与向量的乘法
import numpy as np numpy模块的array相乘时,有两种方式:一是矩阵形式,二是挨个相乘. 需要用矩阵形式相乘时,则要用np.dot()函数. #矩阵与矩阵相乘a = np.ar ...
- Eigen中的矩阵及向量运算
Eigen中的矩阵及向量运算 ,[+,+=,-,-=] ,[\*,\*=] ,[.transpose()] ,[.dot(),.cross(),.adjoint()] ,针对矩阵元素进行的操作[.su ...
- 学习笔记DL005:线性相关、生成子空间,范数,特殊类型矩阵、向量
线性相关.生成子空间. 逆矩阵A⁽-1⁾存在,Ax=b 每个向量b恰好存在一个解.方程组,向量b某些值,可能不存在解,或者存在无限多个解.x.y是方程组的解,z=αx+(1-α),α取任意实数. A列 ...
- Spark机器学习中ml和mllib中矩阵、向量
1:Spark ML与Spark MLLIB区别? Spark MLlib是面向RDD数据抽象的编程工具类库,现在已经逐渐不再被Spark团队支持,逐渐转向Spark ML库,Spark ML是面向D ...
- MathType输入矩阵或者向量的注意事项
如图A区域是换行搞得,BC是插入矩阵,AC明显看着不一样,就是说行间不要使用换行,列间隔不要用空格(ctrl+shift+space),直接插入矩阵,向量就是矩阵的行或者列数目是1. 还有就是需要注意 ...
- 两矩阵各向量余弦相似度计算操作向量化.md
余弦相似度计算: \cos(\bf{v_1}, \bf{v_2}) = \frac{\left( v_1 \times v_2 \right)}{||v_1|| * ||v_2|| } \cos(\b ...
- matlab求矩阵、向量的模
求矩阵的模: function count = juZhenDeMo(a,b) [r,c] = size(a);%求a的行列 [r1,c1] = size(b);%求b的行列 count = 0; f ...
- 掌握Spark机器学习库-05-spark中矩阵与向量的使用
1)介绍 矩阵: Matrix,看做二维表,基本运算(+,-,*,T) 向量: Vectors,方向和大小,基本运算,范数 2)spark中向量的使用(主要使用breeze.linalg) 3)spa ...
随机推荐
- html5——3D案例(立方体)
立方体:父盒子规定了3d呈现属性,立方体做旋转运动 移动顺序:1.每个盒子都先移动100px,然后再做相应的旋转 2.只有这样立方体的几何中心点与父盒子的几何中心点是一样的 <!DOCTYPE ...
- 史上巨坑: vim的"set foldmethod=syntax"设置竟然是导致ctrl+p(ctrl+n)补全在文件稍大时光标位于中间位置补全效率变慢的元凶!
最近我的vim又让我闹心了. 问题出现在supertab的补全速度上, 有时候按下tab键半天才弹出补全列表, 即便是弹出了列表在列表上下移动也变得的相当缓慢, 这让我的很是蛋疼. 在完全无法接受这个 ...
- RHEL7配置中文输入法-智能拼音
RHEL7配置中文输入法-智能拼音 RHEL7.x(CentOS7.x)系统相对之前的6.x系统变化较大,虽然安装时选择了中文环境,但是进入系统后,在控制台及编辑器中仍无法切换输入法进行中文输入. 原 ...
- java中“53”个关键字(含2个保留字)
1.java的关键字(keyword)有多少个? 51+2个保留字=53个关键字(java的关键字都是小写的!!) 2.java的保留字(reserve word)有多少个?问题:分别是什么? 2个保 ...
- CorelDRAW 中文官网 618 48H秒杀开始,多重好礼即刻开抢!
618我有诚意,你呢? 不花钱的618,是残缺的618 给自己一个放肆shopping的机遇 活动力度不够大? 继续升级,终极体验 6月17日—6月18日 618疯狂48小时! 同志们,如果你错过 ...
- NGINX+PHP-FPM7 FastCGI sent in stderr: “Primary script unknown”
https://www.cnblogs.com/hjqjk/p/5651275.html 一开始是Nginx打开网页显示一直是拒绝访问.查看nginx日志是报错显示我的题目,然后就各种搜索解决啊! 百 ...
- Jupyter Notebook 下安装 PHP 内核
我最近被强烈安利了 Jupyter Notebook 这个交互式笔记本.然后试用了它自带的 Python 内核后,这个应用整体给我的感觉很不错,就去搜索了下它所支持的其它内核 Jupyter Kern ...
- 第二节:Series基本属性及方法(下)
- saving snaps iteratively with for loop in Paraview
Goal: read data 1 and slice, then save pressure, velocity contours, close data, then do loop for the ...
- 《hello-world》第八次团队作业:Alpha冲刺-Scrum Meeting 1
项目 内容 这个作业属于哪个课程 2016级计算机科学与工程学院软件工程(西北师范大学) 这个作业的要求在哪里 实验十二 团队作业8:软件测试与Alpha冲刺 团队名称 <hello--worl ...