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

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

?? balance.c

?? 一個用來實現偏微分方程中網格的計算庫
?? C
字號:
/* * Copyright 1997, Regents of the University of Minnesota * * balance.c * * This file contains code that is used to forcefully balance either * bisections or k-sections * * Started 7/29/97 * George * * $Id: balance.c 2501 2007-11-20 02:33:29Z benkirk $ * */#include <metis.h>/************************************************************************** This function is the entry point of the bisection balancing algorithms.**************************************************************************/void Balance2Way(CtrlType *ctrl, GraphType *graph, int *tpwgts, float ubfactor){  int i, j, nvtxs, from, imax, gain, mindiff;  idxtype *id, *ed;  /* Return right away if the balance is OK */  mindiff = abs(tpwgts[0]-graph->pwgts[0]);  if (mindiff < 3*(graph->pwgts[0]+graph->pwgts[1])/graph->nvtxs)    return;  if (graph->pwgts[0] > tpwgts[0] && graph->pwgts[0] < (int)(ubfactor*tpwgts[0]))    return;  if (graph->pwgts[1] > tpwgts[1] && graph->pwgts[1] < (int)(ubfactor*tpwgts[1]))    return;  if (graph->nbnd > 0)    Bnd2WayBalance(ctrl, graph, tpwgts);  else    General2WayBalance(ctrl, graph, tpwgts);}/************************************************************************** This function balances two partitions by moving boundary nodes* from the domain that is overweight to the one that is underweight.**************************************************************************/void Bnd2WayBalance(CtrlType *ctrl, GraphType *graph, int *tpwgts){  int i, ii, j, k, kwgt, nvtxs, nbnd, nswaps, from, to, pass, me, tmp;  idxtype *xadj, *vwgt, *adjncy, *adjwgt, *where, *id, *ed, *bndptr, *bndind, *pwgts;  idxtype *moved, *perm;  PQueueType parts;  int higain, oldgain, mincut, mindiff;  nvtxs = graph->nvtxs;  xadj = graph->xadj;  vwgt = graph->vwgt;  adjncy = graph->adjncy;  adjwgt = graph->adjwgt;  where = graph->where;  id = graph->id;  ed = graph->ed;  pwgts = graph->pwgts;  bndptr = graph->bndptr;  bndind = graph->bndind;  moved = idxwspacemalloc(ctrl, nvtxs);  perm = idxwspacemalloc(ctrl, nvtxs);  /* Determine from which domain you will be moving data */  mindiff = abs(tpwgts[0]-pwgts[0]);  from = (pwgts[0] < tpwgts[0] ? 1 : 0);  to = (from+1)%2;  IFSET(ctrl->dbglvl, DBG_REFINE,      printf("Partitions: [%6d %6d] T[%6d %6d], Nv-Nb[%6d %6d]. ICut: %6d [B]\n",             pwgts[0], pwgts[1], tpwgts[0], tpwgts[1], graph->nvtxs, graph->nbnd, graph->mincut));  tmp = graph->adjwgtsum[idxamax(nvtxs, graph->adjwgtsum)];  PQueueInit(ctrl, &parts, nvtxs, tmp);  idxset(nvtxs, -1, moved);  ASSERT(ComputeCut(graph, where) == graph->mincut);  ASSERT(CheckBnd(graph));  /* Insert the boundary nodes of the proper partition whose size is OK in the priority queue */  nbnd = graph->nbnd;  RandomPermute(nbnd, perm, 1);  for (ii=0; ii<nbnd; ii++) {    i = perm[ii];    ASSERT(ed[bndind[i]] > 0 || id[bndind[i]] == 0);    ASSERT(bndptr[bndind[i]] != -1);    if (where[bndind[i]] == from && vwgt[bndind[i]] <= mindiff)      PQueueInsert(&parts, bndind[i], ed[bndind[i]]-id[bndind[i]]);  }  mincut = graph->mincut;  for (nswaps=0; nswaps<nvtxs; nswaps++) {    if ((higain = PQueueGetMax(&parts)) == -1)      break;    ASSERT(bndptr[higain] != -1);    if (pwgts[to]+vwgt[higain] > tpwgts[to])      break;    mincut -= (ed[higain]-id[higain]);    INC_DEC(pwgts[to], pwgts[from], vwgt[higain]);    where[higain] = to;    moved[higain] = nswaps;    IFSET(ctrl->dbglvl, DBG_MOVEINFO,       printf("Moved %6d from %d. [%3d %3d] %5d [%4d %4d]\n", higain, from, ed[higain]-id[higain], vwgt[higain], mincut, pwgts[0], pwgts[1]));    /**************************************************************    * Update the id[i]/ed[i] values of the affected nodes    ***************************************************************/    SWAP(id[higain], ed[higain], tmp);    if (ed[higain] == 0 && xadj[higain] < xadj[higain+1])       BNDDelete(nbnd, bndind,  bndptr, higain);    for (j=xadj[higain]; j<xadj[higain+1]; j++) {      k = adjncy[j];      oldgain = ed[k]-id[k];      kwgt = (to == where[k] ? adjwgt[j] : -adjwgt[j]);      INC_DEC(id[k], ed[k], kwgt);      /* Update its boundary information and queue position */      if (bndptr[k] != -1) { /* If k was a boundary vertex */        if (ed[k] == 0) { /* Not a boundary vertex any more */          BNDDelete(nbnd, bndind, bndptr, k);          if (moved[k] == -1 && where[k] == from && vwgt[k] <= mindiff)  /* Remove it if in the queues */            PQueueDelete(&parts, k, oldgain);        }        else { /* If it has not been moved, update its position in the queue */          if (moved[k] == -1 && where[k] == from && vwgt[k] <= mindiff)            PQueueUpdate(&parts, k, oldgain, ed[k]-id[k]);        }      }      else {        if (ed[k] > 0) {  /* It will now become a boundary vertex */          BNDInsert(nbnd, bndind, bndptr, k);          if (moved[k] == -1 && where[k] == from && vwgt[k] <= mindiff)             PQueueInsert(&parts, k, ed[k]-id[k]);        }      }    }  }  IFSET(ctrl->dbglvl, DBG_REFINE,     printf("\tMinimum cut: %6d, PWGTS: [%6d %6d], NBND: %6d\n", mincut, pwgts[0], pwgts[1], nbnd));  graph->mincut = mincut;  graph->nbnd = nbnd;  PQueueFree(ctrl, &parts);  idxwspacefree(ctrl, nvtxs);  idxwspacefree(ctrl, nvtxs);}/************************************************************************** This function balances two partitions by moving the highest gain * (including negative gain) vertices to the other domain.* It is used only when tha unbalance is due to non contigous* subdomains. That is, the are no boundary vertices.* It moves vertices from the domain that is overweight to the one that * is underweight.**************************************************************************/void General2WayBalance(CtrlType *ctrl, GraphType *graph, int *tpwgts){  int i, ii, j, k, kwgt, nvtxs, nbnd, nswaps, from, to, pass, me, tmp;  idxtype *xadj, *vwgt, *adjncy, *adjwgt, *where, *id, *ed, *bndptr, *bndind, *pwgts;  idxtype *moved, *perm;  PQueueType parts;  int higain, oldgain, mincut, mindiff;  nvtxs = graph->nvtxs;  xadj = graph->xadj;  vwgt = graph->vwgt;  adjncy = graph->adjncy;  adjwgt = graph->adjwgt;  where = graph->where;  id = graph->id;  ed = graph->ed;  pwgts = graph->pwgts;  bndptr = graph->bndptr;  bndind = graph->bndind;  moved = idxwspacemalloc(ctrl, nvtxs);  perm = idxwspacemalloc(ctrl, nvtxs);  /* Determine from which domain you will be moving data */  mindiff = abs(tpwgts[0]-pwgts[0]);  from = (pwgts[0] < tpwgts[0] ? 1 : 0);  to = (from+1)%2;  IFSET(ctrl->dbglvl, DBG_REFINE,      printf("Partitions: [%6d %6d] T[%6d %6d], Nv-Nb[%6d %6d]. ICut: %6d [B]\n",             pwgts[0], pwgts[1], tpwgts[0], tpwgts[1], graph->nvtxs, graph->nbnd, graph->mincut));  tmp = graph->adjwgtsum[idxamax(nvtxs, graph->adjwgtsum)];  PQueueInit(ctrl, &parts, nvtxs, tmp);  idxset(nvtxs, -1, moved);  ASSERT(ComputeCut(graph, where) == graph->mincut);  ASSERT(CheckBnd(graph));  /* Insert the nodes of the proper partition whose size is OK in the priority queue */  RandomPermute(nvtxs, perm, 1);  for (ii=0; ii<nvtxs; ii++) {    i = perm[ii];    if (where[i] == from && vwgt[i] <= mindiff)      PQueueInsert(&parts, i, ed[i]-id[i]);  }  mincut = graph->mincut;  nbnd = graph->nbnd;  for (nswaps=0; nswaps<nvtxs; nswaps++) {    if ((higain = PQueueGetMax(&parts)) == -1)      break;    if (pwgts[to]+vwgt[higain] > tpwgts[to])      break;    mincut -= (ed[higain]-id[higain]);    INC_DEC(pwgts[to], pwgts[from], vwgt[higain]);    where[higain] = to;    moved[higain] = nswaps;    IFSET(ctrl->dbglvl, DBG_MOVEINFO,       printf("Moved %6d from %d. [%3d %3d] %5d [%4d %4d]\n", higain, from, ed[higain]-id[higain], vwgt[higain], mincut, pwgts[0], pwgts[1]));    /**************************************************************    * Update the id[i]/ed[i] values of the affected nodes    ***************************************************************/    SWAP(id[higain], ed[higain], tmp);    if (ed[higain] == 0 && bndptr[higain] != -1 && xadj[higain] < xadj[higain+1])       BNDDelete(nbnd, bndind,  bndptr, higain);    if (ed[higain] > 0 && bndptr[higain] == -1)      BNDInsert(nbnd, bndind,  bndptr, higain);    for (j=xadj[higain]; j<xadj[higain+1]; j++) {      k = adjncy[j];      oldgain = ed[k]-id[k];      kwgt = (to == where[k] ? adjwgt[j] : -adjwgt[j]);      INC_DEC(id[k], ed[k], kwgt);      /* Update the queue position */      if (moved[k] == -1 && where[k] == from && vwgt[k] <= mindiff)        PQueueUpdate(&parts, k, oldgain, ed[k]-id[k]);      /* Update its boundary information */      if (ed[k] == 0 && bndptr[k] != -1)         BNDDelete(nbnd, bndind, bndptr, k);      else if (ed[k] > 0 && bndptr[k] == -1)          BNDInsert(nbnd, bndind, bndptr, k);    }  }  IFSET(ctrl->dbglvl, DBG_REFINE,     printf("\tMinimum cut: %6d, PWGTS: [%6d %6d], NBND: %6d\n", mincut, pwgts[0], pwgts[1], nbnd));  graph->mincut = mincut;  graph->nbnd = nbnd;  PQueueFree(ctrl, &parts);  idxwspacefree(ctrl, nvtxs);  idxwspacefree(ctrl, nvtxs);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本sm残虐另类| 欧美精品v国产精品v日韩精品 | 国产精品国产三级国产a| 一区二区三国产精华液| 国产精品自拍毛片| 337p亚洲精品色噜噜噜| 亚洲精品日韩综合观看成人91| 精品一区二区三区在线观看国产 | 国产精品一区二区黑丝| 91极品美女在线| 国产亚洲欧美日韩在线一区| 青娱乐精品视频| 欧美精品成人一区二区三区四区| 亚洲情趣在线观看| av在线播放一区二区三区| 久久久精品免费免费| 免费成人在线观看视频| 欧美一卡2卡三卡4卡5免费| 亚洲欧美日韩一区| 99久久99久久精品免费观看| 日本一区二区电影| 国产91丝袜在线播放| 国产欧美日韩另类一区| 国产一区二区调教| 2024国产精品视频| 国产精品一区二区在线播放| 一区二区国产盗摄色噜噜| 成人v精品蜜桃久久一区| 国产婷婷一区二区| 国产精品99久久不卡二区| 精品日本一线二线三线不卡| 久久99精品国产.久久久久久| 日韩一级在线观看| 久久精品国产久精国产| 日韩精品一区二区三区视频 | 亚洲一区欧美一区| 精品视频在线免费| 视频在线观看一区二区三区| 欧美丰满美乳xxx高潮www| 日韩av中文字幕一区二区| 日韩一级二级三级| 国产精品综合av一区二区国产馆| 久久午夜国产精品| 不卡电影免费在线播放一区| 亚洲精品久久久久久国产精华液| 在线免费观看不卡av| 午夜精品免费在线观看| 欧美一级淫片007| 国产成人精品1024| 亚洲精品国产精品乱码不99| 欧美日韩国产高清一区二区三区| 青青草97国产精品免费观看 | 91热门视频在线观看| 一个色在线综合| 欧美精品777| 国产成人在线视频免费播放| 亚洲人吸女人奶水| 欧美一卡二卡在线观看| 国产伦精品一区二区三区视频青涩| 中文字幕欧美国产| 欧美日韩日日夜夜| 国产伦精一区二区三区| 亚洲综合在线五月| www亚洲一区| 欧美性色综合网| 国产一区亚洲一区| 一区二区三区在线视频观看58| 日韩欧美成人午夜| 91在线小视频| 国产揄拍国内精品对白| 亚洲精品久久7777| 亚洲精品一区二区精华| 91欧美一区二区| 免费国产亚洲视频| 亚洲免费观看在线观看| 久久久久久久久久久黄色| 欧美在线观看一区| 国产成人免费9x9x人网站视频| 亚洲一区二区av在线| 中文字幕av一区二区三区免费看 | 国产综合色产在线精品| 亚洲精品国产无天堂网2021| 香蕉加勒比综合久久| 国产日韩欧美a| 欧美一区二区三区啪啪| 99久久精品免费看国产 | 午夜欧美在线一二页| 国产精品久久久久久一区二区三区 | 欧美人动与zoxxxx乱| 丁香激情综合五月| 免费的国产精品| 香港成人在线视频| 一区二区三区中文字幕电影 | 视频一区欧美精品| 亚洲人成在线播放网站岛国| 2022国产精品视频| 日韩精品一区二区三区视频| 欧美日韩国产不卡| 色八戒一区二区三区| 丰满少妇在线播放bd日韩电影| 美国毛片一区二区| 视频一区国产视频| 日韩不卡一二三区| 亚洲制服欧美中文字幕中文字幕| 国产精品日日摸夜夜摸av| 久久久精品人体av艺术| 精品久久久久久综合日本欧美| 91麻豆精品国产91久久久久久| 欧美日韩在线播放三区| 欧美做爰猛烈大尺度电影无法无天| 91免费视频观看| 色94色欧美sute亚洲线路一久| av在线综合网| 一本久久综合亚洲鲁鲁五月天| 91视频www| 欧美综合亚洲图片综合区| 欧美视频日韩视频| 欧美午夜电影在线播放| 欧美色网站导航| 欧美精品一级二级| 欧美一级片免费看| 久久日韩精品一区二区五区| 精品国产免费人成电影在线观看四季 | 色婷婷精品大在线视频| 色欧美片视频在线观看 | 91精品国产乱| 日韩视频不卡中文| 久久人人超碰精品| 国产精品国产三级国产专播品爱网 | 亚洲人成网站影音先锋播放| 亚洲蜜臀av乱码久久精品| 亚洲一区国产视频| 日韩成人精品在线| 精品在线免费视频| 国产白丝网站精品污在线入口| 国产.欧美.日韩| 92精品国产成人观看免费| 欧美日韩在线免费视频| 欧美一区二区精品| 久久国产精品第一页| 精品一区二区三区免费观看| 国产91富婆露脸刺激对白| 99国产一区二区三精品乱码| 在线一区二区观看| 欧美一区二区私人影院日本| 国产日韩欧美综合一区| 一区二区视频在线看| 久久se精品一区精品二区| 成人99免费视频| 欧美一二区视频| 中文字幕在线不卡| 蜜臀a∨国产成人精品| av电影天堂一区二区在线观看| 在线观看视频一区| 337p日本欧洲亚洲大胆色噜噜| 中文字幕在线免费不卡| 天天做天天摸天天爽国产一区 | 亚洲精品在线一区二区| 国产精品成人一区二区三区夜夜夜| 亚洲国产色一区| 国产成人自拍网| 欧美高清你懂得| 国产精品灌醉下药二区| 伦理电影国产精品| 91一区在线观看| 精品噜噜噜噜久久久久久久久试看| 自拍偷拍亚洲欧美日韩| 激情久久久久久久久久久久久久久久 | 日韩一区和二区| 亚洲精品免费电影| 成人天堂资源www在线| 日韩欧美视频一区| 亚洲国产综合人成综合网站| 成人手机电影网| 日韩三级.com| 亚洲一区在线电影| 色综合久久综合中文综合网| 久久久国产精华| 精品一区二区在线免费观看| 欧美精品第1页| 亚洲综合色成人| 91搞黄在线观看| 成人欧美一区二区三区黑人麻豆| 国产一区二区三区在线看麻豆| 91精品麻豆日日躁夜夜躁| 夜夜精品视频一区二区| 成人av在线电影| 国产婷婷色一区二区三区在线| 激情亚洲综合在线| 精品久久久久久久久久久久包黑料| 亚洲va国产天堂va久久en| 在线亚洲一区二区| 亚洲国产一区二区三区| 欧美综合亚洲图片综合区| 亚洲综合清纯丝袜自拍| 欧美色网站导航| 午夜不卡av免费| 制服丝袜在线91| 久久精品国产精品亚洲红杏| 精品黑人一区二区三区久久|