PLM之家精品课程培训

PLM之家精品课程培训

联系电话:18301858168   |   QQ咨询:939801026
NX二次开发培训

NX二次开发培训

UFUN/NXOpen C++和实战案例

适合初级入门或想深入了解二次开发的工程师,本培训结合ufun,NXOpen C++,大量的实例及官方内部的开发技术。
公众号二维码

关注公众号

点击扫描二维码免费在线高清教程

课程详情
Catia二次开发培训

Catia二次开发培训

市场需求大,掌握核心技术前景广阔

Catia二次开发的市场需求大,人才稀缺。掌握开发技能潜力巨大,随着经验积累将在汽车、航空等领域有所作为。
B站二维码

在线原创B站视频

点击关注工业软件传道士主页

课程详情
Teamcenter培训

Teamcenter培训

全方位培训,从基础应用到高级开发全覆盖

涵盖用户应用基础培训、管理员基础培训、管理员高级培训及二次开发培训等全方位内容,由多年经验讲师打造。
QQ群二维码

加入同行交流

点击扫描二维码加入QQ群

课程详情
×

PLM之家plmhome公众号

课程涵盖: PLM之家所有原创视频

×

关注B站视频

所有高清视频一览无余,全部在线播放学习

×

加入PLM之家QQ群

同行交流,疑问解答,更多互助

PLM之家PLMHome-国产软件践行者

[二次开发源码] UG NX二次开发源码分享:矩阵操作的基础算法代码

[复制链接]

2014-8-25 15:14:54 3420 0

admin 发表于 2014-8-25 15:14:54 |阅读模式

admin 楼主

2014-8-25 15:14:54

请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!

您需要 登录 才可以下载或查看,没有账号?注册

x

1 y' ]9 e6 d. x) s0 \1 f0 U1 \+ H0 c+ e0 F( c1 i: a1 ]
$ q0 k& k( v! u+ a
#include <math.h>
" _" A% ^3 B/ ~* m* w* o//矩阵复制
9 l& ]7 P2 A% g1 ], Qvoid Project_Matrix_Copy(double from_mtx[4][4], double to_mtx[4][4])
5 l3 I5 R0 e1 d1 r# J, Z* I{
. [; X( U9 I1 H4 w        int i,j;
& Y7 H5 L, V& g. x! u' P  I7 R) h2 l# K: b7 G
        for(i=0;i<4;i++)) N0 T' o7 b- L& ?1 @
                for(j=0;j<4;j++)
+ w, O, j/ i8 d9 D  \2 @: W. i/ ~                        to_mtx[i][j]=from_mtx[i][j];
1 Z" [) x" S( H1 }  M5 G}/ ^7 q1 n( V# K: t3 U/ i& j
//矩阵初始化- ~2 ]/ B6 O% @0 \4 ~8 P* d
void Project_Matrix_Identity(double mtx[4][4])
3 w5 h+ S8 C) u- f  N% E% z{
! x1 j7 x6 p9 X) q0 T, \/ r* Z        int i,j;% s* X% Z- A3 w3 A9 E9 f* {
        3 s% r0 Q) a& o! J- A
        for(i=0;i<4;i++)! M& s: X! ~: n8 V# W4 |2 G
                for(j=0;j<4;j++)
1 ~$ A0 N& a8 G- j) Y6 S( O; [                        if(i==j)" j- M: y0 p$ ~, }' S+ z) r
                                mtx[i][j]=1.0;
/ y0 g; T" g5 N* [1 K; [0 W" e                        else
7 k/ t* @& ^6 ?% N; S                                mtx[i][j]=0.0;
& Q& B. t/ ?* l+ Z, \# K& z* U}
6 z% e; j0 x1 r9 @1 k//矩阵相乘4 C5 r) T' K8 A% v" N
void Project_Matrix_Product(double left_mtx[4][4],double right_mtx[4][4],double get_mtx[4][4])
. F& v6 M$ Z, Q2 `4 W, r3 \" a{1 P5 y' w% m# a* ?

, ?& }8 _2 s7 [  M4 Y* `        int i,j,k;  J4 Z* C; ?  ?& X, F8 {
        double left[4][4],right[4][4];
& ^8 P' H8 i5 ~6 d3 n  W0 L( t& J6 i# C( d) I% k- O5 K9 t) q
        Project_Matrix_Copy(left_mtx,left);
% C/ J; C; _; N5 w6 \9 X        Project_Matrix_Copy(right_mtx,right);2 A+ A. i% o9 m5 `6 s) H- h0 j/ d( ]
        for(i=0;i<4;i++)
- m/ {6 L4 @- g& j$ }' j. H                for(j=0;j<4;j++)
# Y9 @: `. p! g, C+ k4 q                {
; E4 Q0 i# }8 H0 r# O$ ]" W8 C                        get_mtx[i][j]=0.0;
% j8 D! A% n9 ~, X. ]                        for(k=0;k<4;k++)" x% ~- H7 N5 ~8 U
                                get_mtx[i][j]+=left[i][k]*right[k][j];
1 C  b. `' L: x9 O2 W7 H+ `+ j                }: v! o+ x4 K: ^. ]5 z; ]& @  @
}# X1 g- j7 n5 Y" u  o1 j( [
//转置矩阵0 _6 E! a$ d: Y4 ?% n8 J$ o' h$ a; d
void Project_MatrixGet_Transpose(double mtx[4][4],double transpose_mtx[4][4])
7 n- H8 Q: i3 Y$ z; z( C, s) E{
- z) Y* l- |, L3 A  u/ B        int i,j;, b) t3 R- W9 D9 U. a% r4 d. E3 q
        for(i=0;i<4;i++)
. u: O; i8 y; J. Z        {
! {. Q9 I( r) O  D2 C' h$ G9 V                for(j=0;j<4;j++)& y3 n8 K* |, A# M7 F
                {! v6 w& [# \& O7 b6 Z
                        transpose_mtx[i][j]=mtx[j][i];8 [6 K0 g. a8 ?2 y! u
                }& s" ?$ e! G: H! B" y8 {2 L
        }$ v4 C  n2 ?4 ^6 p$ }. l4 k7 i7 i: x
}
& T$ F% ?& S2 e7 d//从11元组获取变换矩阵% L8 [$ G0 \: q* i! y$ B
void Project_Matrix_Get_From_Move(double translation[3],double point[3],double rotation[3],double angle,double pos[4][4])2 W7 t+ O; B- l8 R/ g
{; h6 l0 i/ I% H' T( s
) \, P: `- _# M4 \+ R! B2 y  O
        //Project_Matrix_Get_Rotation(rotation,point,angle,pos);& ?2 a$ {. I$ B. b( {* b7 G
        int i,j;$ D8 ?; t2 L! i$ i
        for(i=0;i<4;i++)% Z( y' `/ X& k3 ^' F
        for(j=0;j<4;j++)
6 J2 s) E* s( e8 b4 f                if(i==j)! _- b/ M8 W* F4 V* }& k5 z. U# C
                        pos[i][j]=1.0;# s+ w$ Y/ Y: z8 B. o. C2 o8 b
                else
5 ]5 U" C8 w3 `& \5 A                        pos[i][j]=0.0;
- f. B. z( x! K! d        pos[3][0]+=translation[0];) ~# S  Z' X: k( G. c+ y
        pos[3][1]+=translation[1];" u; i1 X" M. j. f" f! Y5 f
        pos[3][2]+=translation[2];
) A& A- A2 U) l  M* D' M/ a}* m( o. E$ X) s3 E( P
//向量缩放$ p# f# L# j- G. S+ Z
void Project_Vector_Scale(double a[3],double scale,double b[3])/ ^1 ?* D$ F3 q; q* L
{9 m6 ?/ I  U4 a5 h2 Q% P& _
        b[0]=a[0]*scale;, M/ r, H8 L& a) _* f
        b[1]=a[1]*scale;
! r- x+ V! c7 l! c        b[2]=a[2]*scale;
- l" k( b( V2 C% a) V& }2 L- w}
2 V2 i- z/ ~4 n6 s
  ]+ n6 x) B! |
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 注册

返回列表 本版积分规则

  • 发布新帖

  • 在线客服

  • 微信

  • 客户端

  • 返回顶部

  • x
    温馨提示

    本网站(plmhome.com)为PLM之家工业软件学习官网站

    展示的视频材料全部免费,需要高清和特殊技术支持请联系 QQ: 939801026

    PLM之家NX CAM二次开发专题模块培训报名开始啦

    我知道了