-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
118 lines (79 loc) · 5.24 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
# Make a database that collects information about the US patent applications
# developed by inventors located into Metropolitan Statistical Areas (MSA)
# Author: Carlo Bottai
# Copyright (c) 2021 - Carlo Bottai
# License: See the LICENSE file.
# Date: 2021-02-05
#################################################
SHELL = bash
.PHONY: all make_patent_database make_citation_database make_readme
.DEFAULT_GOAL:= all
#################################################
DATA_DIR = data
DATA_DIR_RAW = $(DATA_DIR)/raw
DATA_DIR_INTM = $(DATA_DIR)/interim
DATA_DIR_PROC = $(DATA_DIR)/processed
DATA_DIR_USPTO = $(DATA_DIR_RAW)/patentsview
DATA_DIR_PATEX = $(DATA_DIR_RAW)/patex
DATA_DIR_SHP = $(DATA_DIR_RAW)/cartography
SCRIPT_DIR = src
DOCS_DIR = docs
#################################################
USPTO_URL = https://s3.amazonaws.com/data.patentsview.org/20200929/download
USPTO_FILES = patent.tsv.zip application.tsv.zip patent_inventor.tsv.zip location.tsv.zip cpc_current.tsv.zip uspatentcitation.tsv.zip
USPTO_TARGETS := $(foreach F,$(USPTO_FILES),$(DATA_DIR_USPTO)/$F)
$(USPTO_TARGETS): $(DATA_DIR_USPTO)/%: $(SCRIPT_DIR)/download.py
python $< -i $(USPTO_URL)/$* -o $@
PATEX_URL = https://bulkdata.uspto.gov/data/patent/pair/economics/2019
PATEX_FILES = application_data.csv.zip
PATEX_TARGETS := $(foreach F,$(PATEX_FILES),$(DATA_DIR_PATEX)/$F)
$(PATEX_TARGETS): $(DATA_DIR_PATEX)/%: $(SCRIPT_DIR)/download.py
python $< -i $(PATEX_URL)/$* -o $@
SHP_URL = https://www2.census.gov/geo/tiger/GENZ2019/shp
SHP_FILES = cb_2019_us_cbsa_20m.zip
SHP_TARGETS := $(foreach F,$(SHP_FILES),$(DATA_DIR_SHP)/$F)
$(SHP_TARGETS): $(DATA_DIR_SHP)/%: $(SCRIPT_DIR)/download.py
python $< -i $(SHP_URL)/$* -o $@
#################################################
$(DATA_DIR_INTM)/msa_patent.tsv.zip: $(SCRIPT_DIR)/make-patent-database.py $(DATA_DIR_USPTO)/patent.tsv.zip $(DATA_DIR_USPTO)/patent_inventor.tsv.zip $(DATA_DIR_USPTO)/location.tsv.zip $(DATA_DIR_SHP)/cb_2019_us_cbsa_20m.zip
python $< -I $(filter-out $<,$^) -o $@
$(DATA_DIR_INTM)/patent_info.tsv.zip: $(SCRIPT_DIR)/make-patent-info-database.py $(DATA_DIR_USPTO)/patent.tsv.zip $(DATA_DIR_USPTO)/application.tsv.zip $(DATA_DIR_PATEX)/application_data.csv.zip $(DATA_DIR_USPTO)/uspatentcitation.tsv.zip
python $< -I $(filter-out $<,$^) -o $@
$(DATA_DIR_PROC)/msa_patent.tsv.zip: $(SCRIPT_DIR)/make-patent-msa-database.py $(DATA_DIR_INTM)/msa_patent.tsv.zip
python $< -i $(filter-out $<,$^) -o $@
$(DATA_DIR_PROC)/msa_patent_inventor.tsv.zip: $(SCRIPT_DIR)/make-patent-inventor-database.py $(DATA_DIR_INTM)/msa_patent.tsv.zip
python $< -i $(filter-out $<,$^) -o $@
$(DATA_DIR_PROC)/msa_label.tsv.zip: $(SCRIPT_DIR)/make-msa-label-database.py $(DATA_DIR_INTM)/msa_patent.tsv.zip
python $< -i $(filter-out $<,$^) -o $@
$(DATA_DIR_PROC)/msa_citation.tsv.zip: $(SCRIPT_DIR)/make-citation-database.py $(DATA_DIR_PROC)/msa_patent.tsv.zip $(DATA_DIR_USPTO)/uspatentcitation.tsv.zip
python $< -I $(filter-out $<,$^) -o $@
$(DATA_DIR_PROC)/msa_patent_dates.tsv.zip: $(SCRIPT_DIR)/make-patent-dates-database.py $(DATA_DIR_PROC)/msa_patent.tsv.zip $(DATA_DIR_PROC)/msa_citation.tsv.zip $(DATA_DIR_INTM)/patent_info.tsv.zip
python $< -I $(filter-out $<,$^) -o $@
$(DATA_DIR_PROC)/msa_patent_uspc.tsv.zip: $(SCRIPT_DIR)/make-patent-uspc-database.py $(DATA_DIR_PROC)/msa_patent.tsv.zip $(DATA_DIR_PROC)/msa_citation.tsv.zip $(DATA_DIR_INTM)/patent_info.tsv.zip
python $< -I $(filter-out $<,$^) -o $@
$(DATA_DIR_PROC)/msa_patent_quality.tsv.zip: $(SCRIPT_DIR)/make-patent-quality-database.py $(DATA_DIR_PROC)/msa_patent_dates.tsv.zip $(DATA_DIR_PROC)/msa_patent_uspc.tsv.zip $(DATA_DIR_INTM)/patent_info.tsv.zip
python $< -I $(filter-out $<,$^) -o $@
$(DATA_DIR_PROC)/msa_patent_cpc.tsv.zip: $(SCRIPT_DIR)/make-cpc-database.py $(DATA_DIR_PROC)/msa_patent.tsv.zip $(DATA_DIR_PROC)/msa_citation.tsv.zip $(DATA_DIR_USPTO)/cpc_current.tsv.zip
python $< -I $(filter-out $<,$^) -o $@
$(DOCS_DIR)/README_tables.md: $(SCRIPT_DIR)/make-readme-tables.py $(DATA_DIR_PROC)/msa_patent.tsv.zip $(DATA_DIR_PROC)/msa_patent_inventor.tsv.zip $(DATA_DIR_PROC)/msa_patent_quality.tsv.zip $(DATA_DIR_PROC)/msa_label.tsv.zip $(DATA_DIR_PROC)/msa_patent_cpc.tsv.zip $(DATA_DIR_PROC)/msa_citation.tsv.zip
python $< -I $(filter-out $<,$^) -o $@
README.md: $(DOCS_DIR)/README_base.md $(DOCS_DIR)/README_tables.md
awk '{print}' $^ > $@
#################################################
#- all Reproduce all the steps of the project
all: patent_database citation_database readme
#- raw_data Download needed raw data
raw_data: $(USPTO_TARGETS) $(SHP_TARGETS)
#- patent_database Make base tables
patent_database: $(DATA_DIR_PROC)/msa_patent.tsv.zip $(DATA_DIR_PROC)/msa_patent_inventor.tsv.zip $(DATA_DIR_PROC)/msa_patent_info.tsv.zip $(DATA_DIR_PROC)/msa_label.tsv.zip
#- citation_database Make patent-citation table
citation_database: $(DATA_DIR_PROC)/msa_citation.tsv.zip
#- readme Make README file
readme: README.md
#################################################
help : Makefile
@sed -n 's/^#- //p' $<
#- dag_picture Depict the Dependency Acyclic Graph (DAG) of the
#- Makefile (output: makefile.png)
dag_picture:
make -nd all | makefile2graph/make2graph | dot -Tpng -o makefile.png