Find Jobs
Hire Freelancers

DeepWalk algorithm on NVIDA GPU

$1500-3000 USD

已完成
已发布大约 9 年前

$1500-3000 USD

货到付款
DeepWalk ([login to view URL]) is a novel approach for learning latent representations of vertices in a network. These latent representations encode social relations in a continuous vector space, which is easily exploited by statistical models. DeepWalk generalizes recent advancements in language modeling and unsupervised feature learning (or deep learning) from sequences of words to graphs. DeepWalk uses local information obtained from truncated random walks to learn latent representations by treating walks as the equivalent of sentences. We hypothesize that DeepWalks performance could be significantly improved by implementing the solution on a GPU. We are seeking an individual willing to implement a C/C++/Cuda implementation of DeepWalk on a Nvidia GPU that supports CUDA 3.5 or higher. Requirements: Implement a class to perform the deep walk algorithm that implements the following methods. void beforeRun(); // The method that will be called before any iterations start. void afterRun(); // The method that will be called after all iterations are done. void beforeIteration(); // The method that will be called just before an iteration starts. void afterIteration(); // The method that will be called just after an iteration completes. void update(); // The method in which vertex updates need to happen. Will be called on every iteration for every interval. bool hasConverged(); // Should return true if the algorithm converged during execution. void assembleAndSaveFullResultSet(); // Will be called at the end of the execution to assemble results to files that can be sent back for visualization. Input File Format: All files should be in binary format. The graph is divided into sets of sequentially numbered vertices, called intervals. All of the edges with a destination in a given interval are collected into a shard associated with that interval. The edges are then sorted by their source and within that by their destination. The shards are then broken down by the interval of the source vertices to make windows. This is the Parallel Sliding Windows scheme from [login to view URL]~pavlo/courses/fall2013/static/papers/[login to view URL] Each window file contains the adjacency lists for all of the vertices from one interval into another interval. The lists are stored sequentially in the following format. The first value is L, the length of the adjacency list. The next L values are the destination vertices of the associated edges. If a vertex has no adjacencies in the given window, then L is zero. There are two additional meta-data files. The interval file contains the first and last vertex for each of the intervals. The degree file contains the in and out degrees of each vertex. Output File Format: The output file will contain d floating point values for each vertex. The first d values will represent the first vertex in d-dimensional space, and so on. If you are interested in responding please answer the following with you quote. - success of the development effort and testing depends on an understanding of the algorithm, please explain the deepwalk algorithm and provide examples - What CUDA libraries have you used? - Please describe your development environment: which Nvidia GPU do you plan to use for development and unit test of your solution? - Give examples of your experience with CUDA coding?
项目 ID: 7294092

关于此项目

6提案
远程项目
活跃9 年前

想赚点钱吗?

在Freelancer上竞价的好处

设定您的预算和时间范围
为您的工作获得报酬
简要概述您的提案
免费注册和竞标工作
颁发给:
用户头像
I have a bachelor in CS from the American University in Cairo and a minor in Mathematics. I have worked for the past year in Microsoft's Advanced Technology Lab in Cairo (ATLC) as a research assistant in the Computer Vision team. I have worked on various machine learning problems such as object detection and scene recognition and I am an IEEE published author. I have worked extensively on deep learning before and contributed to caffe package on github.
$2,222 USD 在30天之内
5.0 (21条评论)
4.8
4.8
6威客以平均价$1,954 USD来参与此工作竞价
用户头像
Hi! I am professional C/C++/C#/Java programmer. I am able to do this project with highest quality Best Regards, Szymszteinsl
$1,500 USD 在14天之内
4.9 (69条评论)
6.4
6.4
用户头像
Hi. It's me. Tam Nguyen. I'd like to complete this project for you. _------------------------------------------------- Best regards.
$1,666 USD 在29天之内
5.0 (23条评论)
6.1
6.1
用户头像
I am a professional developer having good experience of CUDA. I want to discuss it with you. Hope to hear from you. Best Regards, Khizar
$2,500 USD 在30天之内
5.0 (1条评论)
3.2
3.2
用户头像
How I understand you need to implement DeepWalk algorithm on CUDA 3.5 and higher. I studied literature about DeepWalk approach. How I understand the main idea of algorithm is provide latent representation of vertices in network to encode social relations in a vector space. It uses shorts random walks to learn structural regularities in graphs of the network in question. In one paper I found out the following implementation: After a concrete random walk has been constructed, It uses SkipGram algorithm to update representation. Algorithm iterates over all possible collocations in random walk that appear within the window (shard interval). For each, we map each vertex v_j to its current representation vector Φ(v_j ) ∈ R^d; Given the representation of v_j , we would like to maximize the probability of its neighbours in the walk. To approximate the probability distribution we can use Hierarchical SoftMax algorithm. How I understand you want to apply the PWS method to speed up algorithm using GPU. About my competence in this matter: I have enough experience (about five years) in CUDA. I'm working on Ph.D. thesis in astrophysics department. This work related to the using of GPU for simulations of galaxy dynamics(see my portfolio for another example of implementation on GPU ACO algorithm). I programmed both manually on CUDA and using libraries such as Thrust. About hardware: I plan to use GTX 660 Ti. Probably I will have access to Nvidia Tesla K40. Thank you for attention!
$1,500 USD 在30天之内
5.0 (1条评论)
2.0
2.0
用户头像
Hi, I had around 8 years of industrial experience in the field of FPGAs and computer programming. I had worked on several projects related to GPUs, Network programming, and Parallel programming etc. I can do this project for you. Kind Regards,
$2,500 USD 在30天之内
0.0 (0条评论)
0.0
0.0
用户头像
Hi, I have devloped few alogirthms in CUDA like Bird's flock, sorting, nbody, etc, Best regards
$1,500 USD 在25天之内
0.0 (0条评论)
0.0
0.0

关于客户

UNITED STATES的国旗
Vienna, United States
5.0
1
付款方式已验证
会员自3月 12, 2015起

客户认证

谢谢!我们已通过电子邮件向您发送了索取免费积分的链接。
发送电子邮件时出现问题。请再试一次。
已注册用户 发布工作总数
Freelancer ® is a registered Trademark of Freelancer Technology Pty Limited (ACN 142 189 759)
Copyright © 2024 Freelancer Technology Pty Limited (ACN 142 189 759)
加载预览
授予地理位置权限。
您的登录会话已过期而且您已经登出,请再次登录。