void CTraverseNetCalcu::NetWeight(CMatrix& P)//组权阵 { P.SetSize(iAngleObs + iDistObs, iAngleObs + iDistObs); for (int i = 0; i < (iAngleObs + iDistObs); i++) { for (int j = 0; j < (iAngleObs + iDistObs); j++) { if (i == j)//只有主对角线上才有元素 { if (i < iAngleObs) { P(i, j) = 1; } else P(i, j) = 100 / pDistObs[i - iAngleObs].ObsDist; } } } //double aa = P(iAngleObs + 1, iAngleObs + 1);//检核用的 }
时间: 2024-04-11 17:33:08 浏览: 74
这段代码实现了一个名为`NetWeight`的函数,用于计算组权阵`P`。
首先,通过调用`SetSize`函数设置了`P`矩阵的大小为`(iAngleObs + iDistObs, iAngleObs + iDistObs)`。
然后,通过两个嵌套的循环,遍历`P`矩阵的所有元素。在每个元素处,根据其在矩阵中的位置进行判断。
如果`i`和`j`相等,说明当前元素位于主对角线上,根据`i`的值进行进一步判断。
如果`i`小于`iAngleObs`,说明当前元素对应的是角度观测值,将其赋值为1。
如果`i`大于等于`iAngleObs`,说明当前元素对应的是距离观测值,将其赋值为100除以对应距离观测值的观测距离。
最后,函数结束。
注释部分的代码`//double aa = P(iAngleObs + 1, iAngleObs + 1);//检核用的`是一个注释,用于检核某个特定位置上的矩阵元素的值,不会对程序产生实际影响。
相关问题
//平差接口函数 int CTraverseNetCalcu::AdjustNet() { IterCount = 0; IsAdjustCoor = 0; do { FormErrorEquation(B, L);//组法方程 NetWeight(P);//权阵 Nbb = ~B * P * B; x = Nbb.Inv() * ~B * P * L; V = B * x - L;//(V是加在观测值上的)
这段代码是平差接口函数`AdjustNet()`的一部分,用于进行观测值的平差计算。首先,将迭代次数`IterCount`和是否调整坐标`IsAdjustCoor`初始化为0。
然后,使用do-while循环,进入平差计算的迭代过程。在每次迭代中,调用`FormErrorEquation(B, L)`函数,根据误差方程组法则,组成误差方程`Bx = L`,其中B是未知数系数矩阵,L是观测值向量。
接下来,调用`NetWeight(P)`函数,计算权阵P。权阵用于根据观测值的精度来调整平差结果。
然后,计算法方程`Nbb = ~B * P * B`,其中~B表示B的转置。法方程用于计算未知数的平差值。
接着,通过求解法方程得到未知数的平差值,即`x = Nbb.Inv() * ~B * P * L`。其中Nbb.Inv()表示Nbb的逆矩阵。
最后,计算平差后的残差矩阵V,即`V = B * x - L`。残差矩阵表示平差后的观测值与观测值向量之间的差异。
需要注意的是,该代码段是平差计算的一部分,具体的迭代次数和是否调整坐标的终止条件可能在代码的其他部分中有所定义。
设计两张表,一个【m_id、m_processNo、m_processName、m_type、m_remarks】,另一个是他的外键【m_tareWeight、m_netWeight、m_realDuration、m_currentRotate】
第一个表:
| Column Name | Data Type | Description |
| --- | --- | --- |
| m_id | int | 主键,自增长 |
| m_processNo | varchar(20) | 工序编号 |
| m_processName | varchar(50) | 工序名称 |
| m_type | varchar(50) | 工序类型 |
| m_remarks | varchar(200) | 备注 |
第二个表:
| Column Name | Data Type | Description |
| --- | --- | --- |
| m_id | int | 主键,自增长,关联第一个表的m_id |
| m_tareWeight | float | 皮重 |
| m_netWeight | float | 净重 |
| m_realDuration | int | 实际耗时 |
| m_currentRotate | int | 当前转速 |
阅读全文