Skip to content

Commit 70851a1

Browse files
committed
Merge branch 'features/can-keep-seeing-day-before'
2 parents 91e5193 + 3075f0b commit 70851a1

17 files changed

+2185
-1417
lines changed

.python-version

-1
This file was deleted.

ml/README.md

+5-3
Original file line numberDiff line numberDiff line change
@@ -13,9 +13,11 @@ Detailed explanation [here](http://blog.dimroc.com/2017/11/19/counting-crowds-an
1313
## Setup:
1414

1515
```
16-
# Install docker
17-
pyenv install conda # or wtever u do to get conda going
18-
conda-env create -f environment.yml # or something like this
16+
# Install docker, pyenv and pyenv-virtualenv
17+
pyenv install miniconda3-4.3.11
18+
conda-env create -f environment.yml
19+
pip install -e .
20+
git lfs pull # ensure you have large binaries downloaded
1921
2022
./manage.py --help
2123
```

ml/environment.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -62,7 +62,7 @@ dependencies:
6262
- pexpect=4.2.1=py35_0
6363
- pickleshare=0.7.4=py35_0
6464
- pillow=3.4.2=py35_0
65-
- pip=10.0.1=py35_1
65+
- pip=10.0.1
6666
- prompt_toolkit=1.0.15=py35_0
6767
- ptyprocess=0.5.2=py35_0
6868
- pycodestyle=2.3.1=py35_0

rails/Dockerfile

+7-3
Original file line numberDiff line numberDiff line change
@@ -1,8 +1,12 @@
11
FROM dimroc/docker-ruby-node:latest
22
RUN (wget -q https://www.postgresql.org/media/keys/ACCC4CF8.asc -O - | apt-key add -) && \
3-
echo "deb http://apt.postgresql.org/pub/repos/apt/ jessie-pgdg main" >> /etc/apt/sources.list.d/pgdg.list
4-
RUN apt-get update -qq && apt-get install -y build-essential libpq-dev \
5-
nodejs imagemagick postgresql-client-9.6
3+
echo "deb http://apt.postgresql.org/pub/repos/apt/ jessie-pgdg main\n" >> /etc/apt/sources.list.d/pgdg.list && \
4+
echo "deb http://security.debian.org/debian-security jessie/updates main" >> /etc/apt/sources.list.d/pgdg.list
5+
6+
RUN apt-get remove libpq5 -y && \
7+
apt-get update -qq && \
8+
apt-get install -y build-essential libpq-dev libpq5 nodejs libssl1.0.0 \
9+
imagemagick postgresql-client-9.6
610

711
WORKDIR /app
812
COPY Gemfile Gemfile.lock package.json yarn.lock ./

rails/Gemfile

+3-3
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
source 'https://rubygems.org'
2-
ruby '~> 2.4.1'
2+
ruby '2.5.1'
33
#ruby-gemset=counting_company
44

55
git_source(:github) do |repo_name|
@@ -22,7 +22,7 @@ gem 'env_guard', github: 'dimroc/env_guard'
2222
gem 'external_id', github: 'dimroc/external_id'
2323
gem 'font-awesome-rails'
2424
gem 'friendly_id'
25-
gem 'google-cloud-storage', github: 'dimroc/google-cloud-ruby'
25+
gem 'google-cloud-storage'
2626
gem 'grpc'
2727
gem 'image_processing'
2828
gem 'imgix-rails'
@@ -42,7 +42,7 @@ gem 'shrine-google_cloud_storage', github: 'dimroc/shrine-google_cloud_storage'
4242
gem 'sprockets', '4.0.0beta5'
4343
gem 'turbolinks', '~> 5'
4444
gem 'uglifier', '>= 1.3.0'
45-
gem 'webpacker', github: 'rails/webpacker'
45+
gem 'webpacker'
4646

4747
group :development, :test do
4848
gem 'byebug', platforms: [:mri, :mingw, :x64_mingw]

rails/Gemfile.lock

+41-52
Original file line numberDiff line numberDiff line change
@@ -9,7 +9,7 @@ GIT
99

1010
GIT
1111
remote: https://github.com/dimroc/env_guard.git
12-
revision: 10d5fab025d19a92b6ae94252f1c12a578653ab8
12+
revision: 68f9f5e098a3dd37ec9e3cf67f9f08771cf43e8a
1313
specs:
1414
env_guard (0.1.0)
1515
actionpack (>= 5.0)
@@ -23,20 +23,6 @@ GIT
2323
activerecord
2424
activesupport
2525

26-
GIT
27-
remote: https://github.com/dimroc/google-cloud-ruby.git
28-
revision: 0537fbe1f781586a2f55c605faa37172896821f5
29-
specs:
30-
google-cloud-core (1.0.0)
31-
google-cloud-env (~> 1.0)
32-
googleauth (~> 0.5.1)
33-
google-cloud-env (1.0.1)
34-
faraday (~> 0.11)
35-
google-cloud-storage (1.4.0)
36-
digest-crc (~> 0.4)
37-
google-api-client (~> 0.13.0)
38-
google-cloud-core (~> 1.0)
39-
4026
GIT
4127
remote: https://github.com/dimroc/jshint.git
4228
revision: bc779ab57827be571455e45359958c87fbf1dd1f
@@ -53,15 +39,6 @@ GIT
5339
google-api-client (~> 0.13.0)
5440
shrine (~> 2.0)
5541

56-
GIT
57-
remote: https://github.com/rails/webpacker.git
58-
revision: 3c8adb79201bf4928276936dcbb183c8c029e8f1
59-
specs:
60-
webpacker (3.0.2)
61-
activesupport (>= 4.2)
62-
rack-proxy (>= 0.6.1)
63-
railties (>= 4.2)
64-
6542
GEM
6643
remote: https://rubygems.org/
6744
specs:
@@ -119,7 +96,7 @@ GEM
11996
activerecord (>= 3.0)
12097
autoprefixer-rails (7.1.4)
12198
execjs
122-
bcrypt (3.1.11)
99+
bcrypt (3.1.12)
123100
bindex (0.5.0)
124101
bootstrap (4.0.0.beta)
125102
autoprefixer-rails (>= 6.0.3)
@@ -147,13 +124,13 @@ GEM
147124
concurrent-ruby (1.0.5)
148125
crack (0.4.3)
149126
safe_yaml (~> 1.0.0)
150-
crass (1.0.2)
127+
crass (1.0.4)
151128
declarative (0.0.10)
152129
declarative-option (0.1.0)
153-
devise (4.3.0)
130+
devise (4.4.3)
154131
bcrypt (~> 3.0)
155132
orm_adapter (~> 0.1)
156-
railties (>= 4.1.0, < 5.2)
133+
railties (>= 4.1.0, < 6.0)
157134
responders
158135
warden (~> 1.2.3)
159136
diff-lcs (1.3)
@@ -166,7 +143,7 @@ GEM
166143
activemodel-serializers-xml (~> 1.0)
167144
activesupport (~> 5.0)
168145
request_store (~> 1.0)
169-
erubi (1.7.0)
146+
erubi (1.7.1)
170147
execjs (2.7.0)
171148
factory_girl (4.8.0)
172149
activesupport (>= 3.0.0)
@@ -175,7 +152,7 @@ GEM
175152
railties (>= 3.0.0)
176153
faker (1.8.4)
177154
i18n (~> 0.5)
178-
faraday (0.13.1)
155+
faraday (0.15.2)
179156
multipart-post (>= 1.2, < 3)
180157
ffi (1.9.18)
181158
font-awesome-rails (4.7.0.2)
@@ -197,8 +174,16 @@ GEM
197174
mime-types (~> 3.0)
198175
representable (~> 3.0)
199176
retriable (>= 2.0, < 4.0)
200-
google-protobuf (3.4.1.1)
201-
googleapis-common-protos-types (1.0.0)
177+
google-cloud-core (1.2.2)
178+
google-cloud-env (~> 1.0)
179+
google-cloud-env (1.0.2)
180+
faraday (~> 0.11)
181+
google-cloud-storage (1.5.0)
182+
digest-crc (~> 0.4)
183+
google-api-client (~> 0.13.0)
184+
google-cloud-core (~> 1.0)
185+
google-protobuf (3.6.1)
186+
googleapis-common-protos-types (1.0.2)
202187
google-protobuf (~> 3.0)
203188
googleauth (0.5.3)
204189
faraday (~> 0.12)
@@ -208,14 +193,14 @@ GEM
208193
multi_json (~> 1.11)
209194
os (~> 0.9)
210195
signet (~> 0.7)
211-
grpc (1.6.2)
196+
grpc (1.14.1)
212197
google-protobuf (~> 3.1)
213198
googleapis-common-protos-types (~> 1.0.0)
214-
googleauth (~> 0.5.1)
215199
grpc-tools (1.6.2)
216200
hashdiff (0.3.6)
217201
httpclient (2.8.3)
218-
i18n (0.8.6)
202+
i18n (0.9.5)
203+
concurrent-ruby (~> 1.0)
219204
image_processing (0.4.5)
220205
imgix (1.1.0)
221206
addressable
@@ -247,7 +232,7 @@ GEM
247232
logging (2.2.2)
248233
little-plugger (~> 1.1)
249234
multi_json (~> 1.10)
250-
loofah (2.1.1)
235+
loofah (2.2.2)
251236
crass (~> 1.0.2)
252237
nokogiri (>= 1.5.9)
253238
mail (2.6.6)
@@ -259,11 +244,11 @@ GEM
259244
mime-types-data (3.2016.0521)
260245
mini_magick (4.8.0)
261246
mini_portile2 (2.3.0)
262-
minitest (5.10.3)
263-
multi_json (1.12.2)
247+
minitest (5.11.3)
248+
multi_json (1.13.1)
264249
multipart-post (2.0.0)
265250
nio4r (2.1.0)
266-
nokogiri (1.8.1)
251+
nokogiri (1.8.4)
267252
mini_portile2 (~> 2.3.0)
268253
orm_adapter (0.5.0)
269254
os (0.9.6)
@@ -275,15 +260,15 @@ GEM
275260
pry-byebug (3.5.0)
276261
byebug (~> 9.1)
277262
pry (~> 0.10)
278-
public_suffix (3.0.0)
263+
public_suffix (3.0.2)
279264
puma (3.10.0)
280265
pundit (1.1.0)
281266
activesupport (>= 3.0.0)
282267
pycall (1.0.3)
283-
rack (2.0.3)
284-
rack-proxy (0.6.2)
268+
rack (2.0.5)
269+
rack-proxy (0.6.4)
285270
rack
286-
rack-test (0.7.0)
271+
rack-test (1.1.0)
287272
rack (>= 1.0, < 3)
288273
rails (5.1.4)
289274
actioncable (= 5.1.4)
@@ -300,15 +285,15 @@ GEM
300285
rails-dom-testing (2.0.3)
301286
activesupport (>= 4.2.0)
302287
nokogiri (>= 1.6)
303-
rails-html-sanitizer (1.0.3)
304-
loofah (~> 2.0)
288+
rails-html-sanitizer (1.0.4)
289+
loofah (~> 2.2, >= 2.2.2)
305290
railties (5.1.4)
306291
actionpack (= 5.1.4)
307292
activesupport (= 5.1.4)
308293
method_source
309294
rake (>= 0.8.7)
310295
thor (>= 0.18.1, < 2.0)
311-
rake (12.1.0)
296+
rake (12.3.1)
312297
rb-fsevent (0.10.2)
313298
rb-inotify (0.9.10)
314299
ffi (>= 0.5.0, < 2)
@@ -357,7 +342,7 @@ GEM
357342
down (~> 4.1)
358343
shrine-memory (0.3.0)
359344
shrine (~> 2.2)
360-
signet (0.8.0)
345+
signet (0.8.1)
361346
addressable (~> 2.3)
362347
faraday (~> 0.9)
363348
jwt (>= 1.5, < 3.0)
@@ -388,7 +373,7 @@ GEM
388373
turbolinks (5.0.1)
389374
turbolinks-source (~> 5)
390375
turbolinks-source (5.0.3)
391-
tzinfo (1.2.3)
376+
tzinfo (1.2.5)
392377
thread_safe (~> 0.1)
393378
uber (0.1.0)
394379
uglifier (3.2.0)
@@ -405,6 +390,10 @@ GEM
405390
addressable (>= 2.3.6)
406391
crack (>= 0.3.2)
407392
hashdiff
393+
webpacker (3.5.5)
394+
activesupport (>= 4.2)
395+
rack-proxy (>= 0.6.1)
396+
railties (>= 4.2)
408397
websocket-driver (0.6.5)
409398
websocket-extensions (>= 0.1.0)
410399
websocket-extensions (0.1.2)
@@ -434,7 +423,7 @@ DEPENDENCIES
434423
foreman
435424
friendly_id
436425
fuubar
437-
google-cloud-storage!
426+
google-cloud-storage
438427
grpc
439428
grpc-tools
440429
image_processing
@@ -465,10 +454,10 @@ DEPENDENCIES
465454
uglifier (>= 1.3.0)
466455
web-console (>= 3.3.0)
467456
webmock
468-
webpacker!
457+
webpacker
469458

470459
RUBY VERSION
471-
ruby 2.4.1p111
460+
ruby 2.5.1p57
472461

473462
BUNDLED WITH
474-
1.16.0.pre.2
463+
1.16.2

rails/README.md

+11
Original file line numberDiff line numberDiff line change
@@ -10,8 +10,10 @@ in Madison Square Park, and plots the number of people in line.
1010
Usual rails setup:
1111

1212
```bash
13+
brew install graphicsmagick postgresql redis
1314
yarn install
1415
bundle
16+
export RAILS_ENV=development
1517
rake db:create db:migrate
1618
rails s
1719
```
@@ -25,6 +27,15 @@ export GOOGLE_APPLICATION_CREDENTIALS=../secrets/gcloudstorage.development.json
2527
gcloud config set project counting-company-production
2628
```
2729

30+
### testing
31+
32+
Run the [setup for the /ml portion](../ml/README.md) of crowd count for integration tests against
33+
python machine learning.
34+
35+
```bash
36+
rake # Runs all tests including integration tests w ml
37+
```
38+
2839
### Available Tasks
2940

3041
```

rails/app/javascript/src/clock.vue

+4-3
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,7 @@
11
<template>
22
<section>
3-
<a v-if="today" :href="yesterdays_path">Yesterday</a>
3+
<a v-if="today" :href="day_before_path">Yesterday</a>
4+
<a v-if="!today" :href="day_before_path">Day Before</a>
45
<small>{{time}}</small>
56
<a v-if="!today" :href="todays_path">Now</a>
67
</section>
@@ -19,8 +20,8 @@ export default {
1920
time: function() {
2021
return moment(this.current.created_at).format(MOMENT_FORMAT)
2122
},
22-
yesterdays_path: function() {
23-
return `/dates/${moment().add(-1, 'days').format(this.dateFormat)}`
23+
day_before_path: function() {
24+
return `/dates/${moment(this.date).add(-1, 'days').format(this.dateFormat)}`
2425
},
2526
todays_path: function() {
2627
return `/`

rails/app/views/layouts/application.html.slim

+5-7
Original file line numberDiff line numberDiff line change
@@ -21,14 +21,12 @@ html
2121
.row.justify-content-center
2222
.col-8.my-5
2323
p
24-
' Get in touch with us:
25-
a href="https://twitter.com/CountCompany" @CountCompany
26-
' or
27-
24+
' Get in touch:
25+
a href="https://twitter.com/dimroc" @dimroc
2826
'.
29-
p
27+
p
3028
' Count is a partnership between
31-
a href="http://experiments.dimroc.com/"Evolution of Books LLC
32-
' and
29+
a href="https://experiments.dimroc.com/"Evolution of Books LLC
30+
' and
3331
a href="http://thoughtmerchants.com/"Thought Merchants
3432
'.

rails/app/views/malls/index.html.slim

+1-11
Original file line numberDiff line numberDiff line change
@@ -11,14 +11,4 @@
1111
| .
1212

1313
.col-sm-8
14-
video src="https://dimroc-public.s3.amazonaws.com/mallcount.mp4" controls="true" type="video/mp4" style="max-width:600px;width:100%"
15-
16-
.row.justify-content-center.mt-3
17-
.col-md-8.img-iterate
18-
- @frames.each do |frame|
19-
.linedbox
20-
p.pc
21-
= frame.predictions[1].decorate.crowd_count
22-
span Predicted Crowd
23-
= frame.predictions[1].decorate.density_map_tag
24-
= frame.image_tag
14+
video src="https://dimroc-public.s3.amazonaws.com/mallcount.mp4" controls="true" type="video/mp4" style="max-width:600px;width:100%"

0 commit comments

Comments
 (0)