From a7af0709cc4e032d4e0fee5a3fc4d6a6865d62a6 Mon Sep 17 00:00:00 2001 From: AlexeyAB <alexeyab84@gmail.com> Date: Tue, 13 Dec 2016 12:55:55 +0000 Subject: [PATCH] Added: train_voc.cmd --- Makefile | 94 ++++++++++++++++++++++++++++++++++++----------- 1 files changed, 72 insertions(+), 22 deletions(-) diff --git a/Makefile b/Makefile index 68ed3ee..3d3d5e4 100644 --- a/Makefile +++ b/Makefile @@ -1,32 +1,82 @@ -CC=gcc -COMMON=-Wall `pkg-config --cflags opencv` -I/usr/local/cuda/include/ -UNAME = $(shell uname) -OPTS=-O3 -ifeq ($(UNAME), Darwin) -COMMON+= -isystem /usr/local/Cellar/opencv/2.4.6.1/include/opencv -isystem /usr/local/Cellar/opencv/2.4.6.1/include -LDFLAGS= -framework OpenCL -else -OPTS+= -march=native -LDFLAGS= -lOpenCL -endif -CFLAGS= $(COMMON) $(OPTS) -#CFLAGS= $(COMMON) -O0 -g -LDFLAGS+=`pkg-config --libs opencv` -lm +GPU=0 +CUDNN=0 +OPENCV=0 +DEBUG=0 + +ARCH= -gencode arch=compute_20,code=[sm_20,sm_21] \ + -gencode arch=compute_30,code=sm_30 \ + -gencode arch=compute_35,code=sm_35 \ + -gencode arch=compute_50,code=[sm_50,compute_50] \ + -gencode arch=compute_52,code=[sm_52,compute_52] + +# This is what I use, uncomment if you know your arch and want to specify +# ARCH= -gencode arch=compute_52,code=compute_52 + VPATH=./src/ -EXEC=cnn +EXEC=darknet +OBJDIR=./obj/ -OBJ=network.o image.o tests.o connected_layer.o maxpool_layer.o activations.o list.o option_list.o parser.o utils.o data.o matrix.o softmax_layer.o mini_blas.o convolutional_layer.o opencl.o gpu_gemm.o cpu_gemm.o normalization_layer.o +CC=gcc +NVCC=nvcc +OPTS=-Ofast +LDFLAGS= -lm -pthread +COMMON= +CFLAGS=-Wall -Wfatal-errors -all: $(EXEC) +ifeq ($(DEBUG), 1) +OPTS=-O0 -g +endif -$(EXEC): $(OBJ) - $(CC) $(CFLAGS) $(LDFLAGS) $^ -o $@ +CFLAGS+=$(OPTS) -%.o: %.c - $(CC) $(CFLAGS) -c $< -o $@ +ifeq ($(OPENCV), 1) +COMMON+= -DOPENCV +CFLAGS+= -DOPENCV +LDFLAGS+= `pkg-config --libs opencv` +COMMON+= `pkg-config --cflags opencv` +endif + +ifeq ($(GPU), 1) +COMMON+= -DGPU -I/usr/local/cuda/include/ +CFLAGS+= -DGPU +LDFLAGS+= -L/usr/local/cuda/lib64 -lcuda -lcudart -lcublas -lcurand +endif + +ifeq ($(CUDNN), 1) +COMMON+= -DCUDNN +CFLAGS+= -DCUDNN +LDFLAGS+= -lcudnn +endif + +OBJ=gemm.o utils.o cuda.o convolutional_layer.o list.o image.o activations.o im2col.o col2im.o blas.o crop_layer.o dropout_layer.o maxpool_layer.o softmax_layer.o data.o matrix.o network.o connected_layer.o cost_layer.o parser.o option_list.o darknet.o detection_layer.o captcha.o route_layer.o writing.o box.o nightmare.o normalization_layer.o avgpool_layer.o coco.o dice.o yolo.o detector.o layer.o compare.o classifier.o local_layer.o swag.o shortcut_layer.o activation_layer.o rnn_layer.o gru_layer.o rnn.o rnn_vid.o crnn_layer.o demo.o tag.o cifar.o go.o batchnorm_layer.o art.o region_layer.o reorg_layer.o super.o voxel.o tree.o +ifeq ($(GPU), 1) +LDFLAGS+= -lstdc++ +OBJ+=convolutional_kernels.o activation_kernels.o im2col_kernels.o col2im_kernels.o blas_kernels.o crop_layer_kernels.o dropout_layer_kernels.o maxpool_layer_kernels.o network_kernels.o avgpool_layer_kernels.o +endif + +OBJS = $(addprefix $(OBJDIR), $(OBJ)) +DEPS = $(wildcard src/*.h) Makefile + +all: obj backup results $(EXEC) + +$(EXEC): $(OBJS) + $(CC) $(COMMON) $(CFLAGS) $^ -o $@ $(LDFLAGS) + +$(OBJDIR)%.o: %.c $(DEPS) + $(CC) $(COMMON) $(CFLAGS) -c $< -o $@ + +$(OBJDIR)%.o: %.cu $(DEPS) + $(NVCC) $(ARCH) $(COMMON) --compiler-options "$(CFLAGS)" -c $< -o $@ + +obj: + mkdir -p obj +backup: + mkdir -p backup +results: + mkdir -p results .PHONY: clean clean: - rm -rf $(OBJ) $(EXEC) + rm -rf $(OBJS) $(EXEC) -- Gitblit v1.10.0