From aa5996d58e68edfbefe51061856aecd549dd09c4 Mon Sep 17 00:00:00 2001
From: Joseph Redmon <pjreddie@gmail.com>
Date: Tue, 13 Jan 2015 01:27:08 +0000
Subject: [PATCH] Faster

---
 Makefile |   47 ++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 38 insertions(+), 9 deletions(-)

diff --git a/Makefile b/Makefile
index 6cd3999..3bf04a3 100644
--- a/Makefile
+++ b/Makefile
@@ -1,22 +1,51 @@
+GPU=1
+CLBLAS=0
+
 CC=gcc
-COMMON=-Wall `pkg-config --cflags opencv` -isystem /usr/local/Cellar/opencv/2.4.6.1/include/opencv -isystem /usr/local/Cellar/opencv/2.4.6.1/include
-CFLAGS= $(COMMON) -O3 -ffast-math -flto
-#CFLAGS= $(COMMON) -O0 -g 
-LDFLAGS=`pkg-config --libs opencv` -lm
+COMMON=-Wall -Wfatal-errors `pkg-config --cflags opencv` -I/usr/local/cuda/include/
+ifeq ($(GPU), 1) 
+COMMON+=-DGPU
+endif
+
+ifeq ($(CLBLAS), 1) 
+COMMON+=-DCLBLAS
+LDFLAGS=-lclBLAS
+endif
+
+UNAME = $(shell uname)
+#OPTS=-Ofast -flto
+OPTS=-O3 -flto
+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
+ifeq ($(GPU), 1)
+LDFLAGS= -framework OpenCL
+endif
+else
+OPTS+= -march=native
+ifeq ($(GPU), 1)
+LDFLAGS+= -lOpenCL
+endif
+endif
+CFLAGS= $(COMMON) $(OPTS)
+#CFLAGS= $(COMMON) -O0 -g
+LDFLAGS+=`pkg-config --libs opencv` -lm -pthread
 VPATH=./src/
+EXEC=cnn
+OBJDIR=./obj/
 
-OBJ=network.o image.o tests.o convolutional_layer.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
+OBJ=network.o network_gpu.o image.o cnn.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 gemm.o normalization_layer.o opencl.o im2col.o col2im.o axpy.o dropout_layer.o crop_layer.o freeweight_layer.o cost_layer.o server.o
+OBJS = $(addprefix $(OBJDIR), $(OBJ))
 
-all: cnn
+all: $(EXEC)
 
-cnn: $(OBJ)
+$(EXEC): $(OBJS)
 	$(CC) $(CFLAGS) $(LDFLAGS) $^ -o $@
 
-%.o: %.c 
+$(OBJDIR)%.o: %.c 
 	$(CC) $(CFLAGS) -c $< -o $@
 
 .PHONY: clean
 
 clean:
-	rm -rf $(OBJ) cnn
+	rm -rf $(OBJS) $(EXEC)
 

--
Gitblit v1.10.0