亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? cmatrix.h

?? 陳必紅 編寫的《用C++語言編寫的數學常用算法》光盤內容
?? H
字號:
#ifndef CMATRIX_H

#define CMATRIX_H

#include <iostream.h>
#include <iomanip.h>
#include <stdio.h>

#include "cbuffer.h"
#include "matrix.h"

// 定義復矩陣類
class cmatrix {
 public:
	cbuffer * buf;	// 指向復矩陣緩存類的指針
	size_t rownum, colnum;	// 矩陣的行數與列數
	unsigned istrans:1;	// 轉置標記
	unsigned isneg:1;		// 取負標記
	unsigned isconj:1;	// 共軛標記
	cmatrix(cbuffer * b=0); // 缺省構造函數,產生0行0列空矩陣
	cmatrix(size_t n, cbuffer * b=0); // 產生n維列向量
	cmatrix(size_t r, size_t c, cbuffer * b=0); // 構造函數,構造一個空的復矩陣
	cmatrix(cmatrix& m);	// 拷貝構造函數
	cmatrix(const char * filename, cbuffer * b=0); // 從數據文件構造一個復矩陣
	cmatrix(void * data, size_t r, size_t c=1, cbuffer * b=0);
		 // 從內存數據產生復矩陣
	cmatrix(matrix& m, cbuffer * b=0); // 由實矩陣產生一個內容相同的復矩陣
	cmatrix(matrix& mr, matrix& mi, cbuffer * b=0); // 兩個實矩陣成為實部和虛部
												// 構成一復矩陣
	matrix real();	// 由矩陣的實部生成實矩陣
	matrix image(); // 由矩陣的虛部生成實矩陣
	COMPLEX operator()(size_t r, size_t c); // 重載函數運算符,返回第r行c列的值
	COMPLEX operator()(size_t r);	// 重載函數運算符,返回第r行0列的值,用于向量
	virtual void set(size_t r, size_t c, COMPLEX v) { // 將第r行c列的值設為v
		size_t l;
		v = isneg ? -v : v;
		v = isconj ? ::conj(v) : v;
		l = istrans ? r+c*rownum : r*colnum+c;
		buf = buf->set(l, v); };
	void set(size_t r, COMPLEX v) {
		set(r,0,v);};	// 設置向量中第r個元素的值
	virtual ~cmatrix(){ // 析構函數
		buf->refnum--;	// 緩存的引用數減1
		if(!buf->refnum) delete buf;}; // 如果緩存的引用數為0,則釋放緩存
	cmatrix& operator=(cmatrix& m);	// 重載賦值運算
	cmatrix& operator=(matrix& m); // 將實矩陣賦給復矩陣
	cmatrix& operator=(COMPLEX a); // 將矩陣所有元素設為常數a
	cmatrix operator*(COMPLEX a);	// 數乘矩陣,產生新的矩陣
	cmatrix& operator*=(COMPLEX a); // 數乘矩陣,只是改動原矩陣
	friend cmatrix operator*(COMPLEX a, cmatrix& m); // 數乘矩陣
	cmatrix operator+(COMPLEX a); // 矩陣加常數,產生新矩陣
	cmatrix& operator+=(COMPLEX a); // 矩陣加常數,更動原矩陣
	friend cmatrix operator+(COMPLEX a, cmatrix& m); // 矩陣加常數,常數在前
	cmatrix operator+(cmatrix& m); // 矩陣加法,產生新的矩陣
	cmatrix& operator+=(cmatrix &m); // 矩陣加法,結果取代原矩陣

	cmatrix operator*(cmatrix& m);	// 矩陣乘法,產生并返回新的矩陣
	cmatrix& operator*=(cmatrix& m);	// 矩陣乘法,只是更動原矩陣

	cmatrix operator-(); // 矩陣求負,產生新的矩陣
	cmatrix& neg();	// 將自己求負,不產生新的矩陣

	cmatrix	t();		// 矩陣轉置,產生新的矩陣
	cmatrix& trans()	// 矩陣自身轉置
		{  size_t r = rownum; rownum = colnum; colnum = r; // 交換行數和列數
		istrans = !istrans; return (*this);};
	cmatrix&	conj()	// 矩陣共軛,原矩陣更動
		{isconj = !isconj; return (*this);};
	cmatrix	operator!();		// 矩陣共軛,產生新的矩陣
	cmatrix& transconj()		// 矩陣自身共軛轉置
		{ isconj = !isconj; trans(); return (*this);};
	cmatrix	tc();		// 矩陣共軛轉置,產生新的矩陣

	cmatrix operator-(cmatrix& a);	// 矩陣相減
	cmatrix& operator-=(cmatrix& a); // 矩陣自身減矩陣
	cmatrix& operator-=(COMPLEX a); // 矩陣自身減常數
	cmatrix operator-(COMPLEX a);	// 矩陣減常數,產生新的矩陣
	friend cmatrix operator-(COMPLEX a, cmatrix m); // 常數減矩陣,產生新的矩陣

	void swapr(size_t r1, size_t r2, size_t k=0); // 交換兩行,只交換k列以上
	void swapc(size_t c1, size_t c2, size_t k=0); // 交換兩列,只交換k行以上
	void swap(size_t r1, size_t c1, size_t r2, size_t c2){ // 交換兩個元素
		COMPLEX a; a=(*this)(r1,c1);set(r1,c1,(*this)(r2,c2));
		set(r2,c2,a);};
	DOUBLE maxabs(size_t &r, size_t &c, size_t k=0);
		 // 求主元值和位置,即k行k列之后的最大元素,
		// 元素所在的行列將放在r,c中,返回此元素值
	size_t zgsxy(cmatrix & m, int fn=0);	// 主高斯消元運算
	cmatrix& operator/=(cmatrix m); // 用主高斯消元法求解線性方程的解
		// 矩陣本身為系數矩陣,m為常數向量,返回解向量

	cmatrix& inv();		// 用全選主元高斯-約當法求逆矩陣
	cmatrix operator~();	// 求逆矩陣,但產生新矩陣
	friend cmatrix operator/(COMPLEX a, cmatrix& m); // 求逆矩陣再乘常數
	cmatrix& operator/=(COMPLEX a); // 所有元素乘a的倒數,自身改變
	cmatrix operator/(COMPLEX a); // 所有元素乘a的倒數,產生新的矩陣

	cmatrix& fft(int l=0);


	friend ostream& operator<<(ostream& o, cmatrix& m); // 矩陣的流輸出
	friend istream& operator>>(istream& in, cmatrix& m); // 矩陣的流輸入

	virtual COMPLEX value(size_t r, size_t c) { // 返回第r行c列的復數值
		COMPLEX v;
		v = istrans ? (*buf)[r+c*rownum] : (*buf)[r*colnum+c];
		v = isneg ? -v : v;
		v = isconj ? ::conj(v) : v;
		return v; };
};

inline cmatrix operator*(COMPLEX a, cmatrix& m) {
	return m*a;
};

inline cmatrix operator+(COMPLEX a, cmatrix& m){ // 矩陣加常數,常數在前
	return m+a;
};

cmatrix operator/(COMPLEX a, cmatrix& m); // 求逆矩陣再乘常數


ostream& operator<<(ostream& o, cmatrix& m);
istream& operator>>(istream& in, cmatrix& m);

cmatrix cunit(size_t n);	// 產生n階單位復矩陣

cmatrix fft(matrix& m);	// 對實向量作fft變換
matrix convolute(matrix&a, matrix& b);	// 求矩陣a與b的離散卷積

#endif // CMATRIX_H

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩一区二区三区在线| 国产日产亚洲精品系列| 丁香啪啪综合成人亚洲小说| 青青草成人在线观看| 亚洲午夜视频在线| 亚洲综合激情另类小说区| 亚洲色图第一区| 综合激情成人伊人| 一区二区三区欧美| 亚洲国产精品久久艾草纯爱| 亚洲成av人片| 蜜臀国产一区二区三区在线播放| 午夜精品免费在线观看| 奇米亚洲午夜久久精品| 久久99国产精品尤物| 国产乱对白刺激视频不卡| 国产精品一区久久久久| bt欧美亚洲午夜电影天堂| 色就色 综合激情| 欧美丝袜丝交足nylons| 91麻豆精品国产91久久久久| 日韩精品一区二区在线观看| 精品国产乱码久久久久久蜜臀 | 一区二区三区在线观看国产| 亚洲最新视频在线观看| 蜜桃一区二区三区四区| 国产99久久久国产精品| 在线观看欧美日本| 欧美一区午夜精品| 欧美经典一区二区三区| 亚洲一区二区偷拍精品| 久久精品二区亚洲w码| 国产成人在线免费| 欧美手机在线视频| 久久久久久97三级| 亚洲最大色网站| 国产精品一区二区男女羞羞无遮挡| 成人午夜在线视频| 欧美另类高清zo欧美| 国产日产欧美精品一区二区三区| 一区二区三区日本| 国产一区激情在线| 欧美视频日韩视频| 中文成人av在线| 日韩精品电影一区亚洲| 成人免费av网站| 91精品久久久久久久久99蜜臂| 日本一区二区不卡视频| 日本网站在线观看一区二区三区| 国产成人免费av在线| 欧美电影在哪看比较好| 亚洲天堂免费在线观看视频| 狠狠网亚洲精品| 欧美日韩亚洲综合| 亚洲女同女同女同女同女同69| 狠狠色丁香婷综合久久| 欧美精品视频www在线观看| 国产精品丝袜91| 国产一本一道久久香蕉| 欧美精品一二三| 亚洲精品成人在线| 99久久国产免费看| 国产日韩欧美一区二区三区乱码| 视频一区二区不卡| 欧美日韩成人一区| 亚洲一区二区在线播放相泽| 不卡av在线免费观看| 国产午夜精品久久| 久草中文综合在线| 欧美一区二区精品久久911| 亚洲一区二区视频在线观看| 色综合天天综合狠狠| 国产精品电影一区二区三区| 国产一区二区三区日韩| 欧美mv日韩mv国产| 久久99精品久久久久| 正在播放亚洲一区| 日韩av网站免费在线| 91精品免费在线观看| 丝袜美腿亚洲综合| 911国产精品| 蜜桃精品视频在线观看| 91精品国产入口| 蜜臀99久久精品久久久久久软件| 91 com成人网| 美女高潮久久久| 精品国产乱码久久久久久牛牛| 久久国产综合精品| 久久久精品免费网站| 粉嫩高潮美女一区二区三区| 国产精品三级视频| 91丨porny丨国产入口| 亚洲美女少妇撒尿| 欧美日本免费一区二区三区| 蜜桃一区二区三区在线观看| 久久久综合视频| 99久久久无码国产精品| 一区二区三区日韩在线观看| 欧美精品 国产精品| 韩国v欧美v亚洲v日本v| 久久精品人人做人人爽97| 99久久精品国产导航| 亚洲成人av在线电影| 精品对白一区国产伦| 风流少妇一区二区| 亚洲成人一二三| 久久嫩草精品久久久精品| hitomi一区二区三区精品| 亚洲第一在线综合网站| 亚洲精品一区在线观看| 色综合天天性综合| 蜜臀av性久久久久av蜜臀妖精| 欧美高清在线精品一区| 欧美亚洲综合一区| 国产一区二区在线电影| 亚洲精品成人精品456| 精品国免费一区二区三区| aaa亚洲精品| 七七婷婷婷婷精品国产| 中文字幕亚洲欧美在线不卡| 这里只有精品视频在线观看| 不卡的av电影| 久久se精品一区精品二区| 亚洲色图20p| 久久精品网站免费观看| 欧美精品在欧美一区二区少妇| 高清国产午夜精品久久久久久| 一区二区三区在线观看视频| 国产午夜精品一区二区 | 欧美亚洲国产一区在线观看网站| 麻豆一区二区在线| 亚洲国产欧美一区二区三区丁香婷 | 麻豆成人av在线| 亚洲午夜三级在线| 中文字幕亚洲欧美在线不卡| 久久色中文字幕| 日韩午夜激情视频| 欧美日韩国产一级| 欧洲精品一区二区| 91麻豆swag| 成人午夜精品在线| 国产成人在线视频播放| 麻豆成人av在线| 日本在线不卡视频一二三区| 亚洲成人自拍网| 亚洲综合男人的天堂| 亚洲视频狠狠干| 中文字幕一区二区三区在线播放| 精品久久久久久久久久久久包黑料 | 91亚洲国产成人精品一区二三| 国产最新精品免费| 久久成人羞羞网站| 麻豆成人av在线| 久久综合综合久久综合| 美女在线观看视频一区二区| 偷拍自拍另类欧美| 日本一区中文字幕 | 精品福利二区三区| 久久这里只精品最新地址| xf在线a精品一区二区视频网站| 日韩欧美123| 欧美zozozo| 国产视频一区不卡| 国产精品少妇自拍| 亚洲卡通动漫在线| 亚洲午夜免费视频| 秋霞午夜av一区二区三区| 毛片av中文字幕一区二区| 久久精品国产99| 国产成人av影院| 一本色道久久综合精品竹菊| 91色乱码一区二区三区| 欧美日韩精品一二三区| 欧美一区二区三区四区高清| 久久青草国产手机看片福利盒子| 国产三级欧美三级日产三级99| 国产精品午夜电影| 一区二区三区不卡视频在线观看| 一区二区三区在线观看网站| 日韩制服丝袜先锋影音| 国产精品一区二区在线看| 99re这里都是精品| 欧美放荡的少妇| 国产女人18水真多18精品一级做| 亚洲欧洲成人av每日更新| 同产精品九九九| 国产精品综合在线视频| 99re这里只有精品视频首页| 欧美日韩在线观看一区二区| 久久免费精品国产久精品久久久久| 日本一区二区三区高清不卡| 亚洲伊人伊色伊影伊综合网| 日韩在线一区二区三区| 成人午夜大片免费观看| 欧美日韩国产精品自在自线| 国产片一区二区| 午夜精品一区二区三区电影天堂 | 国产精品久久久久永久免费观看 | 中文字幕亚洲在| 久久99久久精品|