轻松上手:Linux下metis与mt-metis的全面安装和使用教程

本文涉及的产品
语种识别,语种识别 100万字符
图片翻译,图片翻译 100张
文档翻译,文档翻译 1千页
简介: Linux下的metis与mt-metis的安装和使用本文的Linux包括VMare和windows下的WSL环境下安装metis串行和并行本文还讲述了电脑的线程以及和超线程的区别,如何寻找,如何判别,请看下文

Linux下的metis与mt-metis的安装和使用

  • 本文的Linux包括VMare和windows下的WSL环境下安装metis串行和并行
  • 本文还讲述了电脑的线程以及和超线程的区别,如何寻找,如何判别,请看下文

装备:

  1. Ubuntu18.6.4LTS
  2. gcc7.5.0
  3. cmake version 3.10.2

metis的安装

别相信网上的一键sudo apt-get install libmetis-dev,有很多问题!!!

  1. 下载链接->metis-5.1.0.tar.gz
  2. 解压成文件夹,名字假设为A
  3. 打开A/include/metis.h,根据自己电脑的位数(32or64)选择
// 64位
#define IDXTYPEWIDTH 64 
// 32位
#define IDXTYPEWIDTH 32
  1. 在A目录执行以下编译命令
make config
make
sudo make install
  1. 可能出现的问题:
  1. make[2]: Leaving directory '/home/xxx/metis/build/Linux-x86_64'
  1. 无伤大雅,没有问题
  1. 配置环境
  1. sudo vim /etc/ld.so.conf
  2. 末尾添加include /usr/local/bin保存
  3. 运行sudo ldconfig更新
  1. 测试环境
#include <cstddef> /* NULL */
#include <metis.h>
#include <iostream>
#include <vector>
int main(){
    idx_t nVertices = 6;//顶点个数
    idx_t nEdges    = 7;//边的条数
    idx_t nWeights  = 1;//权重
    idx_t nParts    = 2;//几类
    idx_t objval;
    std::vector<idx_t> part(nVertices, 0);
    // Indexes of starting points in adjacent array
    std::vector<idx_t> xadj = {0,2,5,7,9,12,14};
    // Adjacent vertices in consecutive index order
    std::vector<idx_t> adjncy = {1,3,0,4,2,1,5,0,4,3,1,5,4,2};
    // Weights of vertices
    // if all weights are equal then can be set to NULL
    std::vector<idx_t> vwgt(nVertices * nWeights, 0);
    int ret = METIS_PartGraphKway(&nVertices,& nWeights, xadj.data(), adjncy.data(),
                       NULL, NULL, NULL, &nParts, NULL,
                         NULL, NULL, &objval, part.data());
    std::cout << ret << std::endl;
    for(unsigned part_i = 0; part_i < part.size(); part_i++){
    std::cout << part_i << " " << part[part_i] << std::endl;
    }
    return 0;
}
  1. g++ -std=c++11 test.cpp -o test -lmetis
  2. 结果:
1
0 1
1 0
2 0
3 1
4 1
5 0

ps:分割是随机的,只要看你是不是分为0,1共2类

mt-metis的安装

mt-metis就是metis的多线程版本,能够进行并行计算
  1. 下载链接->mt-metis-0.7.2.tar.gz
  2. 解压成文件夹,名字假设为A
  3. 打开A/metis/include/metis.h,根据自己电脑的位数(32or64)选择
// 64位
#define IDXTYPEWIDTH 64 
// 32位
#define IDXTYPEWIDTH 32
  1. 回到A目录里,运行编译命令
./configure
make
sudo make install
  1. 可能的问题
  1. ./configure:command not found解决办法sh configure 然后添加执行权限 chmod u+x configure
  2. 如果是wsl安装,把第一个命令改成bash ./configure即可
  1. 使用方法
mtmetis test.graph 2 test.part -t -T n

解释:

  1. test.graph 是图表的文件,例如下面内容:第一行就是顶点和边的个数,顶点从1开始,下面就是每两个顶点连接成的边
10 10
10 2
1 3
2 4
3 5
4 6
5 7
6 8
7 9
8 10
9 1
  1. 2是分成的类别数量
  2. test.part是分割后生成的文件
  3. -t能显示mtmetis的运行时间
  4. -T n n代表线程数量,默认以全部线程数,不能超过最大的线程数

超线程与线程

接着上题,你可能会疑惑该如何查找自己的线程数量为多少?那什么又是超线程呢?
  • 以windows为例,打开任务管理器-》性能
  • 能够看到右下角有内核逻辑处理器,能发现逻辑处理器=内核*2,这里的逻辑处理器数量就是超线程数量,线程数量=内核数量
  • 超线程是intel提出的虚拟化处理器,在高性能计算中我们不能使用超线程,因此一定要知道自己最真实的线程数量有多少
  • 在vmare虚拟机的处理器配置中也用到了超线程,为了规避这种情况,可以设置1个处理器,内核数量为真实线程数量(因为每个人就是1个CPU处理器,x核,而intel使用超线程让内核*2)
  • 你可能还看到左侧线程有3000,4000。刚刚又说电脑只有n个总线程,远小于他!xd,可别忘了,线程切换的开销很小,电脑一会就切换了好多线程,所以你看到了有3,4k。


目录
相关文章
|
3月前
|
Ubuntu Linux
计算机基础知识:linux系统怎么安装?
在虚拟机软件中创建一个新的虚拟机,并选择相应操作系统类型和硬盘空间大小等参数。将下载的 ISO 镜像文件加载到虚拟机中。启动虚拟机,进入安装界面,并按照步骤进行安装。安装完成后,可以在虚拟机中使用 Linux 系统。
|
1月前
|
安全 Linux iOS开发
Nessus Professional 10.10 Auto Installer for RHEL 10, AlmaLinux 10, Rocky Linux 10 - Nessus 自动化安装程序
Nessus Professional 10.10 Auto Installer for RHEL 10, AlmaLinux 10, Rocky Linux 10 - Nessus 自动化安装程序
138 6
Nessus Professional 10.10 Auto Installer for RHEL 10, AlmaLinux 10, Rocky Linux 10 - Nessus 自动化安装程序
|
1月前
|
存储 Linux 开发工具
Linux环境下使用Buildroot配置软件包
使用Buildroot可以大大简化嵌入式Linux系统的开发和维护工作,但它需要对Linux系统和交叉编译有深入的理解。通过上述步骤,可以有效地配置和定制软件包,为特定的嵌入式应用构建高效、稳定的系统。
189 11
|
1月前
|
消息中间件 Kafka Linux
Linux下安装Kafka 3.9.1
本文介绍Kafka 3.9.1版本的安装与配置,包括通过ZooKeeper或KRaft模式启动Kafka。涵盖环境变量设置、日志路径修改、集群UUID生成、存储格式化及服务启停操作,适用于Linux环境下的部署实践。
218 0
|
3月前
|
存储 监控 Linux
Linux环境锁定关键文件防止误删操作流程。
总结以上内容,在Linux环境下锁定重要文档避免误删涉及到多种技术手段与策略组合运作, 包括但不限于利用chatter指挥官固化文档状态至只读模式、运作ACL精准调整访问权利列表、编排自动化流程简
146 20
|
3月前
|
Linux
Linux环境下的UDEV机制及其与守护进程的关联
实际使用时管理员需要熟悉编写合适udev rules去满足特殊需求;同时也需要注意避免编写过度复杂导致无法预料结果rules.UDEVD虽然稳健但错误配置可能导致无法预料问题因此需谨慎处理相关配置工作.
143 16
|
3月前
|
网络协议 关系型数据库 Linux
【App Service Linux】在Linux App Service中安装 tcpdump 并抓取网络包
在App Service for Linux环境中,无法像Windows一样直接使用网络排查工具抓包。本文介绍了如何通过TCPDUMP在Linux环境下抓取网络包,包括SSH进入容器、安装tcpdump、执行抓包命令及下载分析文件的完整操作步骤。
200 5
|
3月前
|
存储 Linux
Linux环境下删除大文件后磁盘空间未释放问题诊断流程。
以上诊断流程涉及Linux底层机制与高级管理技能结合之处,并需要管理员根据实际环境灵活调整诊断策略与解决方案。
262 8
下一篇
oss云网关配置