umap降维,c++用法纪实

全是血泪,可惜对于大量数据,速度还是太慢。

一、代码

// ConsoleApplication2.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//

#include <iostream>


#include "knncolle/knncolle.hpp"
#include "Umap.hpp"

#include <iostream>
#include <vector>


int main() {
    int ndim = 1000; // 数据的维度
    int nobs = 200000; // 观测值数量
    std::vector<double> data(ndim * nobs); // 输入数据数组
    std::vector<double> embedding(nobs * 2); // 用于存储UMAP嵌入结果

    // 初始化输入数据,这里用随机数填充
    for (int i = 0; i < ndim * nobs; ++i) {
        data[i] = static_cast<double>(rand()) / RAND_MAX; // 用随机数填充数据
    }

    umappp::Umap x;

    x.set_num_neighbors(30).set_num_epochs(100);

    x.run(ndim, nobs, data.data(), 2, embedding.data());

    // 处理嵌入结果,例如打印嵌入结果
    for (int i = 0; i < nobs; ++i) {
        std::cout << "Point " << i << ": (" << embedding[2 * i] << ", " << embedding[2 * i + 1] << ")" << std::endl;
    }

    return 0;
}

二、环境配置

1、 设置

 

 

 

2、包含文件

这些包含文件都在我的百度网盘,分享如下:
链接:https://pan.baidu.com/s/1luXsa5IqcOFSWclGqPwd1Q 
提取码:syoa 
--来自百度网盘超级会员V4的分享

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值