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

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

?? pf_vector.c

?? 機器人仿真平臺,和stage配合運行
?? C
字號:
/************************************************************************** * Desc: Vector functions * Author: Andrew Howard * Date: 10 Dec 2002 * CVS: $Id: pf_vector.c,v 1.3.2.1 2003/04/18 19:01:18 inspectorg Exp $ *************************************************************************/#include <math.h>#include <gsl/gsl_matrix.h>#include <gsl/gsl_eigen.h>#include <gsl/gsl_linalg.h>#include "pf_vector.h"// Return a zero vectorpf_vector_t pf_vector_zero(){  pf_vector_t c;  c.v[0] = 0.0;  c.v[1] = 0.0;  c.v[2] = 0.0;    return c;}// Check for NAN or INF in any componentint pf_vector_finite(pf_vector_t a){  int i;    for (i = 0; i < 3; i++)    if (!finite(a.v[i]))      return 0;    return 1;}// Print a vectorvoid pf_vector_fprintf(pf_vector_t a, FILE *file, const char *fmt){  int i;  for (i = 0; i < 3; i++)  {    fprintf(file, fmt, a.v[i]);    fprintf(file, " ");  }  fprintf(file, "\n");  return;     }// Simple vector additionpf_vector_t pf_vector_add(pf_vector_t a, pf_vector_t b){  pf_vector_t c;  c.v[0] = a.v[0] + b.v[0];  c.v[1] = a.v[1] + b.v[1];  c.v[2] = a.v[2] + b.v[2];    return c;}// Simple vector subtractionpf_vector_t pf_vector_sub(pf_vector_t a, pf_vector_t b){  pf_vector_t c;  c.v[0] = a.v[0] - b.v[0];  c.v[1] = a.v[1] - b.v[1];  c.v[2] = a.v[2] - b.v[2];    return c;}// Transform from local to global coords (a + b)pf_vector_t pf_vector_coord_add(pf_vector_t a, pf_vector_t b){  pf_vector_t c;  c.v[0] = b.v[0] + a.v[0] * cos(b.v[2]) - a.v[1] * sin(b.v[2]);  c.v[1] = b.v[1] + a.v[0] * sin(b.v[2]) + a.v[1] * cos(b.v[2]);  c.v[2] = b.v[2] + a.v[2];    return c;}// Transform from global to local coords (a - b)pf_vector_t pf_vector_coord_sub(pf_vector_t a, pf_vector_t b){  pf_vector_t c;  c.v[0] = +(a.v[0] - b.v[0]) * cos(b.v[2]) + (a.v[1] - b.v[1]) * sin(b.v[2]);  c.v[1] = -(a.v[0] - b.v[0]) * sin(b.v[2]) + (a.v[1] - b.v[1]) * cos(b.v[2]);  c.v[2] = a.v[2] - b.v[2];    return c;}// Return a zero matrixpf_matrix_t pf_matrix_zero(){  int i, j;  pf_matrix_t c;  for (i = 0; i < 3; i++)    for (j = 0; j < 3; j++)      c.m[i][j] = 0.0;          return c;}// Check for NAN or INF in any componentint pf_matrix_finite(pf_matrix_t a){  int i, j;    for (i = 0; i < 3; i++)    for (j = 0; j < 3; j++)      if (!finite(a.m[i][j]))        return 0;    return 1;}// Print a matrixvoid pf_matrix_fprintf(pf_matrix_t a, FILE *file, const char *fmt){  int i, j;  for (i = 0; i < 3; i++)  {    for (j = 0; j < 3; j++)    {      fprintf(file, fmt, a.m[i][j]);      fprintf(file, " ");    }    fprintf(file, "\n");  }  return;     }// Compute the matrix inversepf_matrix_t pf_matrix_inverse(pf_matrix_t a, double *det){  double lndet;  int signum;  gsl_permutation *p;  gsl_matrix_view A, Ai;  pf_matrix_t ai;  A = gsl_matrix_view_array((double*) a.m, 3, 3);  Ai = gsl_matrix_view_array((double*) ai.m, 3, 3);    // Do LU decomposition  p = gsl_permutation_alloc(3);  gsl_linalg_LU_decomp(&A.matrix, p, &signum);  // Check for underflow  lndet = gsl_linalg_LU_lndet(&A.matrix);  if (lndet < -1000)  {    //printf("underflow in matrix inverse lndet = %f", lndet);    gsl_matrix_set_zero(&Ai.matrix);  }  else  {    // Compute inverse    gsl_linalg_LU_invert(&A.matrix, p, &Ai.matrix);  }  gsl_permutation_free(p);  if (det)    *det = exp(lndet);  return ai;}// Decompose a covariance matrix [a] into a rotation matrix [r] and a diagonal// matrix [d] such that a = r d r^T.void pf_matrix_unitary(pf_matrix_t *r, pf_matrix_t *d, pf_matrix_t a){  int i, j;  gsl_matrix *aa;  gsl_vector *eval;  gsl_matrix *evec;  gsl_eigen_symmv_workspace *w;  aa = gsl_matrix_alloc(3, 3);  eval = gsl_vector_alloc(3);  evec = gsl_matrix_alloc(3, 3);  for (i = 0; i < 3; i++)    for (j = 0; j < 3; j++)      gsl_matrix_set(aa, i, j, a.m[i][j]);  // Compute eigenvectors/values  w = gsl_eigen_symmv_alloc(3);  gsl_eigen_symmv(aa, eval, evec, w);  gsl_eigen_symmv_free(w);  *d = pf_matrix_zero();  for (i = 0; i < 3; i++)  {    d->m[i][i] = gsl_vector_get(eval, i);    for (j = 0; j < 3; j++)      r->m[i][j] = gsl_matrix_get(evec, i, j);  }    gsl_matrix_free(evec);  gsl_vector_free(eval);  gsl_matrix_free(aa);    return;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色丁香久综合在线久综合在线观看| 奇米影视7777精品一区二区| 日韩精品一区在线| 欧美性做爰猛烈叫床潮| 欧美在线啊v一区| 91精品91久久久中77777| 色网站国产精品| 日本乱人伦一区| 欧美羞羞免费网站| 欧美视频在线一区| 91精品国产一区二区三区香蕉| 欧美无人高清视频在线观看| 欧美日韩国产小视频在线观看| 欧美日韩国产乱码电影| 欧美一区二区啪啪| 精品免费国产一区二区三区四区| 26uuu精品一区二区| 欧美国产日本韩| 亚洲精品第一国产综合野| 亚洲高清一区二区三区| 日韩电影在线一区二区三区| 九九热在线视频观看这里只有精品| 老司机午夜精品99久久| 成人av电影在线观看| 日本高清不卡在线观看| 欧美一级片在线观看| 国产欧美一区二区三区网站| 亚洲美女在线一区| 美女任你摸久久| 不卡的av网站| 欧美福利电影网| 国产午夜一区二区三区| 一区二区在线观看免费视频播放| 日本怡春院一区二区| 懂色av一区二区夜夜嗨| 欧美日韩一级大片网址| 久久尤物电影视频在线观看| 亚洲欧美激情视频在线观看一区二区三区| 亚洲国产成人精品视频| 国产黄人亚洲片| 欧美日韩一级二级三级| 中文字幕在线不卡一区| 五月激情六月综合| 福利电影一区二区三区| 欧美一区二区三区视频| 综合色中文字幕| 国产美女精品一区二区三区| 欧美天堂一区二区三区| 国产精品免费网站在线观看| 久久精品理论片| 欧美日韩中文国产| 成人欧美一区二区三区白人| 精品夜夜嗨av一区二区三区| 在线亚洲+欧美+日本专区| 中文字幕不卡在线| 久久电影国产免费久久电影| 欧美日韩一区成人| 亚洲精品国产无套在线观| 丁香婷婷综合网| 久久综合九色综合97_久久久| 日韩国产精品久久久| 欧美又粗又大又爽| 亚洲色图在线看| 波多野结衣亚洲一区| 国产调教视频一区| 国模大尺度一区二区三区| 欧美一区二区黄| 日韩激情视频网站| 欧美区在线观看| 午夜激情综合网| 欧美日韩黄色一区二区| 亚洲最新视频在线播放| 色悠悠久久综合| 中文字幕亚洲成人| 91麻豆精品国产91久久久久久久久| 中文字幕一区日韩精品欧美| 99九九99九九九视频精品| 337p粉嫩大胆噜噜噜噜噜91av| 亚洲欧美日韩成人高清在线一区| 成人理论电影网| 国产精品视频你懂的| 成人午夜精品在线| 中文字幕亚洲区| 日本精品一区二区三区四区的功能| 综合自拍亚洲综合图不卡区| 91在线视频观看| 亚洲成人资源网| 日韩美女一区二区三区| 国内欧美视频一区二区| 久久九九99视频| 91偷拍与自偷拍精品| 亚洲国产一区二区视频| 91精品国产91综合久久蜜臀| 久草这里只有精品视频| 中文字幕不卡一区| 在线视频你懂得一区| 日韩高清不卡一区| 久久精品欧美日韩精品| 一本色道综合亚洲| 免费精品视频最新在线| 精品国产乱码久久久久久久久| 国产精品白丝jk白祙喷水网站| 亚洲欧洲精品成人久久奇米网| 欧美影院一区二区| 国产一区二区三区| 亚洲黄色小视频| 欧美一区二区三区视频免费播放 | 欧美三区免费完整视频在线观看| 亚洲一区在线观看网站| 精品国产污网站| 一本色道久久综合亚洲aⅴ蜜桃| 图片区小说区区亚洲影院| 久久久久久久免费视频了| 成人精品亚洲人成在线| 午夜激情综合网| 国产精品福利一区| 日韩一区二区免费在线电影| 9i在线看片成人免费| 日韩中文字幕一区二区三区| 国产精品久久久久久亚洲毛片| 欧美日韩一区在线观看| 国产a区久久久| 人人精品人人爱| 亚洲美女在线国产| 久久亚洲捆绑美女| 欧美电影一区二区三区| k8久久久一区二区三区| 黑人巨大精品欧美黑白配亚洲| 夜夜操天天操亚洲| 国产精品不卡在线| 久久先锋影音av鲁色资源 | 天堂av在线一区| 亚洲三级久久久| 欧美高清在线视频| 日韩欧美视频一区| 欧美日本一道本在线视频| 91蜜桃网址入口| 成人app下载| 国产精品亚洲成人| 国产一区二区调教| 美女一区二区三区| 麻豆精品在线播放| 午夜免费欧美电影| 午夜精品福利久久久| 亚洲国产日韩一级| 一区二区三区 在线观看视频| 国产精品久久久久久久久果冻传媒 | 国产欧美日韩一区二区三区在线观看| 欧美卡1卡2卡| 欧美美女喷水视频| 欧美绝品在线观看成人午夜影视| 欧美午夜宅男影院| 欧美亚洲精品一区| 欧美日韩国产另类一区| 欧美亚州韩日在线看免费版国语版| 91看片淫黄大片一级| 色吊一区二区三区| 欧美日韩国产精品自在自线| 欧美日韩国产123区| 欧美日韩精品一区二区三区四区| 在线一区二区三区四区五区 | 欧美色精品在线视频| 欧美亚洲高清一区| 制服丝袜亚洲色图| 日韩免费视频线观看| 国产亚洲一本大道中文在线| 国产精品三级在线观看| 亚洲视频在线一区| 亚洲综合色区另类av| 视频在线观看一区二区三区| 久久成人免费电影| av午夜精品一区二区三区| 91久久人澡人人添人人爽欧美| 欧美日韩大陆在线| 日韩久久久精品| 中文字幕不卡一区| 亚洲成av人影院在线观看网| 美女网站色91| www.日本不卡| 欧美精品第一页| 久久日一线二线三线suv| 亚洲四区在线观看| 日本一区中文字幕| 国产**成人网毛片九色| 欧美午夜精品一区二区三区| 欧美大片免费久久精品三p | 亚洲va中文字幕| 国产一区日韩二区欧美三区| 成人黄色在线视频| 欧美高清性hdvideosex| 久久久欧美精品sm网站| 亚洲麻豆国产自偷在线| 精一区二区三区| 色av成人天堂桃色av| 久久久综合精品| 亚洲二区视频在线| 成人高清伦理免费影院在线观看| 欧美精品九九99久久| 国产精品乱人伦| 久久精品国产网站|