Project for Java course.
Nowadays, many widely-known companies, like Google or Netflix, have a lot of tasks involving machine learning running all the time (like Netflix's recommendation system or Google photos search engine) and having all the neural networks for that being prepared, tuned and properly working is a rather hard managing task. This project is a prototype of a command-line manager for maintaining a bunch of tasks each with a dataset that it is trained on and a neural network architecture that it is trained with. It allows for an easy execution of train or test process at the server as well.
mvn clean && mvn installTo start and stop server:
./startServer.sh
./stopServer.shTo execute client:
java -Djava.security.policy=client.policy -cp target/classes main.MainYou will be provided with instructions in the command line while ml-manager is running.
Custom datasets should have the following structure:
datasetName
- samples
- sample1Name.ext
- sample2Name.ext ...
 
- labels
- sample1Name.txt
- sample2Name.txt ...
 
Project uses JavaRMI to communicate with the server, JavaNativeInterface to train/test tasks and MongoDB API to connect with a database, containing task list. Besides Java and C++, project uses Python's Tensorflow to take advantage of Python's ML nature. Remote operations (involving the change of tasks Map) are safe and synchronized. I intended to use C++ Tensorflow API instead of Python's, but Azure server, the only remote one I can use, have to little RAM (adding swap memory didn't help either). Due to that also, I do not recommend using neural networks other than MobileNet, because they are quite hard for Azure's resources and preparing of those architecture may last longer than RMI waiting timeout. Also, MNIST and COCO datasets aren't actually of any use, because of their size, which could not be stored on Azure server. However, IMAGENET and CUSTOM are available with no issues.