diff --git a/homework_1/Makefile b/homework_1/Makefile new file mode 100644 index 0000000..7bfadec --- /dev/null +++ b/homework_1/Makefile @@ -0,0 +1,261 @@ +# +# PDS homework_1 Makefile +# +# Copyright (C) 2024 Christos Choutouridis +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU Lesser General Public License as +# published by the Free Software Foundation, either version 3 +# of the License, or (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public License +# along with this program. If not, see . +# + +# ============== Project settings ============== +# Project's name +PROJECT := PDS_homework_1 +# Excecutable's name +TARGET := knnsearch +# Source directories list(space seperated). Makefile-relative path, UNDER current directory. +SRC_DIR_LIST := src +# Include directories list(space seperated). Makefile-relative path. +INC_DIR_LIST := src inc +# Exclude files list(space seperated). Filenames only. +# EXC_FILE_LIST := bad.cpp old.cpp + +# Build directories +BUILD_DIR := bin +OBJ_DIR := $(BUILD_DIR)/obj +DEP_DIR := $(BUILD_DIR)/.dep + + +# ========== Compiler settings ========== +# Compiler flags for debug and release +DEB_CFLAGS := -DDEBUG -g3 -Wall -Wextra -std=c11 +REL_CFLAGS := -Wall -Wextra -O3 -std=c11 +DEB_CXXFLAGS := -DDEBUG -g3 -Wall -Wextra -std=c++17 +REL_CXXFLAGS := -Wall -Wextra -O3 -std=c++17 + +# Pre-defines +# PRE_DEFS := MYCAB=1729 SUPER_MODE +PRE_DEFS := + +# ============== Linker settings ============== +# Linker flags (example: -pthread -lm) +LDFLAGS := -pthread +# Map output file +MAP_FILE := output.map +MAP_FLAG := -Xlinker -Map=$(BUILD_DIR)/$(MAP_FILE) + +# ============== Docker settings ============== +# We need: +# - Bind the entire project directory(the dir that icludes all the code) as volume. +# - In docker instance, change to working directory(where the makefile is). +DOCKER_VOL_DIR := $${PWD} +DOCKER_WRK_DIR := +DOCKER_RUN := docker run --rm +DOCKER_FLAGS := -v $(DOCKER_VOL_DIR):/usr/src/$(PROJECT) -w /usr/src/$(PROJECT)/$(DOCKER_WRK_DIR) + +# docker invoke mechanism (edit with care) +# note: +# Here, `DOCKER` variable is empty. Rules can assign `DOCKER := DOCKER_CMD` when docker +# functionality is needed. +DOCKER_CMD = $(DOCKER_RUN) $(DOCKER_FLAGS) $(IMAGE) +DOCKER := + +# ============== Tool selection ============== +# compiler and compiler flags. +CSIZE := size +CFLAGS := $(DEB_CFLAGS) +CXXFLAGS := $(DEB_CXXFLAGS) +CXX := g++ + + +# +# =========== Main body and Patterns =========== +# + +#ifeq ($(OS), Windows_NT) +# TARGET := $(TARGET).exe +#endif +INC := $(foreach dir,$(INC_DIR_LIST),-I$(dir)) +DEF := $(foreach def,$(PRE_DEFS),-D$(def)) +EXC := $(foreach fil,$(EXC_FILE_LIST), \ + $(foreach dir,$(SRC_DIR_LIST),$(wildcard $(dir)/$(fil))) \ + ) +# source files. object and dependencies list +# recursive search into current and source directories +SRC := $(wildcard *.cpp) +SRC += $(foreach dir,$(SRC_DIR_LIST),$(wildcard $(dir)/*.cpp)) +SRC += $(foreach dir,$(SRC_DIR_LIST),$(wildcard $(dir)/**/*.cpp)) +SRC := $(filter-out $(EXC),$(SRC)) +#SRC := $(abspath $(SRC)) + +OBJ := $(foreach file,$(SRC:%.cpp=%.o),$(OBJ_DIR)/$(file)) +DEP := $(foreach file,$(SRC:%.cpp=%.d),$(DEP_DIR)/$(file)) + + +# Make Dependencies pattern. +# This little trick enables recompilation only when dependencies change +# and it does so for changes both in source AND header files ;) +# +# It is based on Tom Tromey's method. +# +# Invoke cpp to create makefile rules with dependencies for each source file +$(DEP_DIR)/%.d: %.c + @mkdir -p $(@D) + @$(DOCKER) $(CC) -E $(CFLAGS) $(INC) $(DEF) -MM -MT $(OBJ_DIR)/$(<:.c=.o) -MF $@ $< + +# c file objects depent on .c AND dependency files, which have an empty recipe +$(OBJ_DIR)/%.o: %.c $(DEP_DIR)/%.d + @mkdir -p $(@D) + $(DOCKER) $(CC) -c $(CFLAGS) $(INC) $(DEF) -o $@ $< + +$(DEP_DIR)/%.d: %.cpp + @mkdir -p $(@D) + @$(DOCKER) $(CXX) -E $(CXXFLAGS) $(INC) $(DEF) -MM -MT $(OBJ_DIR)/$(<:.cpp=.o) -MF $@ $< + +# cpp file objects depent on .cpp AND dependency files, which have an empty recipe +$(OBJ_DIR)/%.o: %.cpp $(DEP_DIR)/%.d + @mkdir -p $(@D) + $(DOCKER) $(CXX) -c $(CXXFLAGS) $(INC) $(DEF) -o $@ $< + +# empty recipe for dependency files. This prevents make errors +$(DEP): + +# now include all dependencies +# After all they are makefile dependency rules ;) +include $(wildcard $(DEP)) + +# main target rule +$(BUILD_DIR)/$(TARGET): $(OBJ) + @mkdir -p $(@D) + @echo Linking to target: $(TARGET) + @echo $(DOCKER) $(CXX) $(LDFLAGS) $(MAP_FLAG) -o $(@D)/$(TARGET) '$$(OBJ)' + @$(DOCKER) $(CXX) $(LDFLAGS) $(MAP_FLAG) -o $(@D)/$(TARGET) $(OBJ) + @echo + @echo Print size information + @$(CSIZE) $(@D)/$(TARGET) + @echo Done + +.PHONY: clean +clean: + @echo Cleaning build directories + @rm -rf $(OBJ_DIR) + @rm -rf $(DEP_DIR) + @rm -rf $(BUILD_DIR) + +# +# ================ Local build rules ================= +# example: +# make debug + +debug: CFLAGS := $(DEB_CFLAGS) +debug: $(BUILD_DIR)/$(TARGET) + +release: CFLAGS := $(REL_CFLAGS) +release: $(BUILD_DIR)/$(TARGET) + +all: release + +hpc-results/post: + $(CXX) $(CFLAGS) -o $@ hpc-results/main.cpp + +hpc-clean: + rm hpc-results/post + +# +# ================ Local via docker build rules ================= +# +# examples: +# make IMAGE=hpcimage v0 +# make IMAGE=hpcimage v1_cilk +# +local_v0: CFLAGS := $(DEB_CFLAGS) -DCODE_VERSION=0 +local_v0: CXXFLAGS := $(DEB_CXXFLAGS) -DCODE_VERSION=0 +local_v0: TARGET := local_v0 +local_v0: $(BUILD_DIR)/$(TARGET) + cp $(BUILD_DIR)/$(TARGET) out/$(TARGET) + +local_v1: CFLAGS := $(DEB_CFLAGS) -DCODE_VERSION=4 +local_v1: CXXFLAGS := $(DEB_CXXFLAGS) -DCODE_VERSION=4 +local_v1: TARGET := local_v1 +local_v1: $(BUILD_DIR)/$(TARGET) + cp $(BUILD_DIR)/$(TARGET) out/$(TARGET) + +v0: DOCKER := $(DOCKER_CMD) +v0: CFLAGS := $(REL_CFLAGS) -DCODE_VERSION=0 +v0: CXXFLAGS := $(REL_CXXFLAGS) -DCODE_VERSION=0 +v0: TARGET := knnsearch_v0 +v0: $(BUILD_DIR)/$(TARGET) + cp $(BUILD_DIR)/$(TARGET) out/$(TARGET) + +v1_cilk: DOCKER := $(DOCKER_CMD) +v1_cilk: CXX := /usr/local/OpenCilk-9.0.1-Linux/bin/clang++ +v1_cilk: CFLAGS := $(REL_CFLAGS) -fcilkplus -DCODE_VERSION=1 -DCILK +v1_cilk: CXXFLAGS := $(REL_CXXFLAGS) -fcilkplus -DCODE_VERSION=1 -DCILK +v1_cilk: LDFLAGS += -fcilkplus +v1_cilk: TARGET := knnsearch_cilkv1 +v1_cilk: $(BUILD_DIR)/$(TARGET) + cp $(BUILD_DIR)/$(TARGET) out/$(TARGET) + +v1_omp: DOCKER := $(DOCKER_CMD) +v1_omp: CFLAGS := $(REL_CFLAGS) -fopenmp -DCODE_VERSION=1 -DOMP +v1_omp: CXXFLAGS := $(REL_CXXFLAGS) -fopenmp -DCODE_VERSION=1 -DOMP +v1_omp: LDFLAGS += -fopenmp +v1_omp: TARGET := knnsearch_ompv1 +v1_omp: $(BUILD_DIR)/$(TARGET) + cp $(BUILD_DIR)/$(TARGET) out/$(TARGET) + +v1: DOCKER := $(DOCKER_CMD) +v1: CFLAGS := $(REL_CFLAGS) -DCODE_VERSION=1 +v1: CXXFLAGS := $(REL_CXXFLAGS) -DCODE_VERSION=1 +v1: TARGET := knnsearch_v1 +v1: $(BUILD_DIR)/$(TARGET) + cp $(BUILD_DIR)/$(TARGET) out/$(TARGET) + + + +# +# ========= Inside CSAL Image build rules =========== +# +# 1) first jump into image (make sure you are in the directory where Makefile is): +# > docker run -it -v ${PWD}:/usr/src/exercise_1 -w /usr/src/exercise_1/ hpcimage +# 2) Clean binaries first **important** +# > make clean +# 3) for v4 cilk for example: +# > make csal_v4_cilk +# 4) run executables from `bin/`. Examples: +# > ./bin/tcount_ompv3 -i mtx/NACA0015.mtx --timing -r 3 -o /dev/null +# > ./bin/tcount_pthv4 -i mtx/com_Youtube.mtx --timing --dynamic --print_count + +csal_v0: CFLAGS := $(REL_CFLAGS) -DCODE_VERSION=0 +csal_v0: TARGET := knnsearch_v0 +csal_v0: $(BUILD_DIR)/$(TARGET) + +csal_v1_cilk: CXX := /usr/local/OpenCilk-9.0.1-Linux/bin/clang++ +csal_v1_cilk: CFLAGS := $(REL_CFLAGS) -fcilkplus -DCODE_VERSION=1 -DCILK +csal_v1_cilk: CXXFLAGS := $(REL_CXXFLAGS) -fcilkplus -DCODE_VERSION=1 -DCILK +csal_v1_cilk: LDFLAGS += -fcilkplus +csal_v1_cilk: TARGET := knnsearch_cilkv1 +csal_v1_cilk: $(BUILD_DIR)/$(TARGET) + +csal_v1_omp: CFLAGS := $(REL_CFLAGS) -fopenmp -DCODE_VERSION=1 -DOMP +csal_v1_omp: CXXFLAGS := $(REL_CXXFLAGS) -fopenmp -DCODE_VERSION=1 -DOMP +csal_v1_omp: LDFLAGS += -fopenmp +csal_v1_omp: TARGET := knnsearch_ompv1 +csal_v1_omp: $(BUILD_DIR)/$(TARGET) + +csal_v1: CFLAGS := $(REL_CFLAGS) -DCODE_VERSION=1 +csal_v1: CXXFLAGS := $(REL_CXXFLAGS) -DCODE_VERSION=1 +csal_v1: TARGET := knnsearch_v1 +csal_v1: $(BUILD_DIR)/$(TARGET) + + + diff --git a/homework_1/report/.gitignore b/homework_1/report/.gitignore new file mode 100644 index 0000000..77ec3e4 --- /dev/null +++ b/homework_1/report/.gitignore @@ -0,0 +1,7 @@ +# Texstudio +*.out +*.aux +*.log +*.toc +*.synctex.gz + diff --git a/homework_1/report/homework_1_report.pdf b/homework_1/report/homework_1_report.pdf new file mode 100644 index 0000000..f88d8e4 Binary files /dev/null and b/homework_1/report/homework_1_report.pdf differ diff --git a/homework_1/report/homework_1_report.tex b/homework_1/report/homework_1_report.tex new file mode 100644 index 0000000..dc64304 --- /dev/null +++ b/homework_1/report/homework_1_report.tex @@ -0,0 +1,50 @@ +% +% Network programming Lab sum report +% +% authors: +% Χρήστος Χουτουρίδης ΑΕΜ 8997 +% cchoutou@ece.auth.gr + + +\documentclass[a4paper, 11pt]{AUTHReport} + +% Document configuration +\AuthorName{Χρήστος Χουτουρίδης} +\AuthorMail{cchoutou@ece.auth.gr} +\AuthorAEM{8997} + +%\CoAuthorName{asdf} +%\CoAuthorMail{asdf} +%\CoAuthorAEM{9874} + +%\WorkGroup{Ομάδα 3} + +\DocTitle{Εργασία 1: knnsearch} +\DocSubTitle{Συστήματα με κοινή μνήμη} +\Department{Τμημα ΗΜΜΥ. Τομεάς Ηλεκτρονικής} +\ClassName{Παράλληλα και Διανεμημένα Συστήματα} + +\InstructorName{Νικόλαος Πιτσιάνης} +\InstructorMail{nikos.pitsianis@eng.auth.gr} +\CurrentDate{\today} + + +\usepackage{capt-of} +\usepackage{enumitem} +\usepackage{tabularx} +\usepackage{array} + +\begin{document} + +\setlist[itemize]{topsep=0pt, partopsep=0pt, itemsep=3pt, parsep=3pt} + +\InsertTitle + +%\tableofcontents + +\sloppy + +\section{Εισαγωγή} + + +\end{document} diff --git a/homework_1/src/main.cpp b/homework_1/src/main.cpp new file mode 100644 index 0000000..4af4fc0 --- /dev/null +++ b/homework_1/src/main.cpp @@ -0,0 +1,6 @@ +#include + +int main(){ + std::cout << "Hello from knnsearch\n"; + return 0; +}