⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 _assert_mreldifs.ado

📁 是一个经济学管理应用软件 很难找的 但是经济学学生又必须用到
💻 ADO
字号:
*! version 1.0.0  10jan2005
program _assert_mreldifs
	version 8
	syntax anything [, tol(real 1e-8) noNames noList ]
			
	gettoken matexp1 matexp2 : anything, match(parens)
	if `"`matexp2'"' == "" {
		dis as err "two matrix expressions expected"
		exit 198
	}	
		
	tempname M1 M2
	matrix `M1' = `matexp1'
	matrix `M2' = `matexp2' 
	
	if ( (rowsof(`M1') != rowsof(`M2')) | ///
	     (colsof(`M1') != colsof(`M2')) ) {
	    	dis as err "inconformable matrices or matrix expressions" 
	    	dis as err `"  {ralign 12:`matexp1'} = "' rowsof(`M1') ///
	    	                                    " x " colsof(`M1')
	    	dis as err `"  {ralign 12:`matexp2'} = "' rowsof(`M2') ///
	    	                                    " x " colsof(`M2')
	    	exit 503
	}
	
	// for speed, first straight test 
	capture assert mreldif(`M1',`M2') < `tol' 
	if _rc {
		// test by column, up to sign
		tempname  M1_j M2_j M2m_j
		
		local c = colsof(`M1')
		forvalues j = 1/`c' { 
			matrix `M1_j'  = `M1'[1...,`j']
			matrix `M2_j'  = `M2'[1...,`j']
			matrix `M2m_j' = - `M2_j'
		
			capture assert ///
			   (mreldif(`M1_j',`M2_j' ) < `tol') | ///
			   (mreldif(`M1_j',`M2m_j') < `tol')
		               
			if _rc {
				dis as err "assert failed: " /// 
				    `"mreldif(`matexp1',`matexp2') < `tol'"'
				    
				if "`list'" == "" { 
					matlist `M1', title(`matexp1')
					matlist `M2', title(`matexp2')
				}
				
				exit 9
			}
		}	
	}
	
	if "`names'" == "" {
		_assert_streq `"`:rowfullnames `M1''"' /// 
		              `"`:rowfullnames `M2''"'
		              
		_assert_streq `"`:colfullnames `M1''"' /// 
		              `"`:colfullnames `M2''"'
	}
end
exit

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -