Cramer‘s Rule

cramer.js

javascript 复制代码
function Cramer2(vec2x2A, vec2B) {
	this.A = vec2x2A;
	this.B = vec2B;
}
Cramer2.det2 = function(v) {
	return v[0][0] * v[1][1] - v[0][1] * v[1][0];
};
Cramer2.xCol = function(vec2x2A, B, col) {
	var nVec = [];
	var i, j;
	for (i = 0; i < 2; i++) {
		nVec[i] = [];
		for (j = 0; j < 2; j++) {
			if (j == col) {
				nVec[i].push(B[i]);
			} else {
				nVec[i].push(vec2x2A[i][j]);
			}
		}
	}
	return nVec;
}
Cramer2.prototype.getX = function() {
	var D, Dx, Dy;
	
	D = Cramer2.det2(this.A);
	Dx = Cramer2.det2( Cramer2.xCol(this.A, this.B, 0) );
	Dy = Cramer2.det2( Cramer2.xCol(this.A, this.B, 1) );
	
	return [Dx/D, Dy/D];
}


function Cramer3(vec3x3A, vec3B) {
	this.A = vec3x3A;
	this.B = vec3B;
}

Cramer3.det3 = function(v) {
	return v[0][0] * (v[1][1]*v[2][2] - v[2][1]*v[1][2]) - 
			v[0][1] * (v[1][0]*v[2][2] - v[2][0]*v[1][2]) +
			v[0][2] * (v[1][0]*v[2][1] - v[2][0]*v[1][1]);
};

Cramer3.xCol = function(v3x3, B, col) {
	var nVec = [];
	var i, j;
	for (i = 0; i < 3; i++) {
		nVec[i] = [];
		for (j = 0; j < 3; j++) {
			if (j == col) {
				nVec[i].push(B[i]);
			} else {
				nVec[i].push(v3x3[i][j]);
			}
		}
	}
	return nVec;
}

Cramer3.prototype.getX = function() {
	var D, Dx, Dy, Dz;
	
	D = Cramer3.det3(this.A);
	Dx = Cramer3.det3( Cramer3.xCol(this.A, this.B, 0) );
	Dy = Cramer3.det3( Cramer3.xCol(this.A, this.B, 1) );
	Dz = Cramer3.det3( Cramer3.xCol(this.A, this.B, 2) );
	
	return [Dx/D, Dy/D, Dz/D];
}

module.exports = {
	Cramer2: Cramer2,
	Cramer3: Cramer3
};

* index.js

javascript 复制代码
var cramer = require("./cramer");

/* 2x-y=1 and x-3y=8 */
var A = [[2,-1],[1,-3]], B = [1, 8];
var cramer2 = new cramer.Cramer2(A, B);
console.log(cramer2.getX());

/* x+y+z=2, 2x + y + 3z = 9, and x - 3y + z = 10 */
A = [ [1,1,1], [2,1,3], [1,-3,1] ];
B = [2, 9, 10];
var cramer3 = new cramer.Cramer3(A, B);
console.log(cramer3.getX()); /* [1,-2,3] */

Cramer's Rule

相关推荐
learning-striving10 小时前
kali连不上网解决方法
linux·开发语言·网络·php·kali
田野追逐星光10 小时前
STL容器list的模拟实现
开发语言·c++·list
NCDS程序员10 小时前
v-model: /v-model/ :(v-bind)三者核心区别
前端·javascript·vue.js
夏幻灵11 小时前
CSS三大特性:层叠、继承与优先级解析
前端·css
摇滚侠11 小时前
macbook shell 客户端推荐 Electerm macbook 版本下载链接
java·开发语言
程序员布吉岛11 小时前
Java 后端定时任务怎么选:@Scheduled、Quartz 还是 XXL-Job?(对比 + 避坑 + 选型)
java·开发语言
C++ 老炮儿的技术栈11 小时前
Qt Creator中不写代如何设置 QLabel的颜色
c语言·开发语言·c++·qt·算法
知无不研11 小时前
lambda表达式的原理和由来
java·开发语言·c++·lambda表达式
lili-felicity11 小时前
CANN多模型并发部署与资源隔离
开发语言·人工智能
小龙报11 小时前
【51单片机】深度解析 51 串口 UART:原理、配置、收发实现与工程化应用全总结
c语言·开发语言·c++·stm32·单片机·嵌入式硬件·51单片机