j1-template 2022.2.2 → 2022.3.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/_includes/themes/j1/blocks/footer/boxes/contacts_box.proc +46 -18
- data/_includes/themes/j1/blocks/footer/boxes/links_box.proc +1 -0
- data/assets/data/fab.html +2 -2
- data/assets/data/footer.html +2 -2
- data/assets/themes/j1/adapter/js/analytics.js +13 -13
- data/assets/themes/j1/adapter/js/cookieConsent.js +1 -1
- data/assets/themes/j1/adapter/js/nbinteract.js +366 -120
- data/assets/themes/j1/core/css/themes/unodark/bootstrap.css +30 -40
- data/assets/themes/j1/core/css/themes/unodark/bootstrap.min.css +1 -1
- data/assets/themes/j1/core/css/themes/unolight/bootstrap.css +85 -216
- data/assets/themes/j1/core/css/themes/unolight/bootstrap.min.css +2 -2
- data/assets/themes/j1/core/js/template.js +1 -1
- data/assets/themes/j1/core/js/template.min.js +1 -1
- data/assets/themes/j1/core/js/template.min.js.map +1 -1
- data/assets/themes/j1/modules/carousel/css/theme/uno.css +5 -0
- data/assets/themes/j1/modules/carousel/css/theme/uno.min.css +1 -1
- data/assets/themes/j1/modules/cookieConsent/js/cookieConsent.js +1 -0
- data/assets/themes/j1/modules/justifiedGallery/css/justifiedGallery.css +6 -0
- data/assets/themes/j1/modules/justifiedGallery/css/justifiedGallery.min.css +1 -1
- data/assets/themes/j1/modules/mmenuLight/css/mmenu-light.css +2 -2
- data/assets/themes/j1/modules/mmenuLight/css/mmenu-light.min.css +1 -2
- data/assets/themes/j1/modules/nbInteract/README.md +169 -0
- data/assets/themes/j1/modules/nbInteract/css/nbinteract-core.css +4 -0
- data/assets/themes/j1/modules/nbInteract/css/nbinteract-core.min.css +4 -0
- data/assets/themes/j1/modules/nbInteract/css/theme/uno/nbinteract-core.css +33 -33
- data/assets/themes/j1/modules/nbInteract/css/theme/uno/nbinteract-core.min.css +1 -1
- data/assets/themes/j1/modules/nbInteract/js/requireJS/require.js +2068 -0
- data/assets/themes/j1/modules/nbInteract/js/requireJS/require.min.js +36 -0
- data/assets/themes/j1/modules/plotly/LICENSE +21 -0
- data/assets/themes/j1/modules/plotly/README.md +32 -0
- data/assets/themes/j1/modules/plotly/js/plotly.js +265345 -0
- data/assets/themes/j1/modules/plotly/js/plotly.min.js +65 -0
- data/assets/themes/j1/modules/requirejs/LICENSE +45 -0
- data/assets/themes/j1/modules/requirejs/README.md +79 -0
- data/assets/themes/j1/modules/requirejs/js/require.js +2068 -0
- data/assets/themes/j1/modules/requirejs/js/require.min.js +36 -0
- data/lib/j1/version.rb +1 -1
- data/lib/starter_web/Gemfile +1 -1
- data/lib/starter_web/_config.yml +1 -1
- data/lib/starter_web/_data/blocks/defaults/footer.yml +25 -17
- data/lib/starter_web/_data/blocks/footer.yml +78 -65
- data/lib/starter_web/_data/modules/analytics.yml +8 -23
- data/lib/starter_web/_data/modules/defaults/analytics.yml +1 -1
- data/lib/starter_web/_data/modules/defaults/cookieconsent.yml +4 -1
- data/lib/starter_web/_data/modules/justifiedGallery.yml +14 -8
- data/lib/starter_web/_data/modules/navigator_menu.yml +6 -3
- data/lib/starter_web/_data/modules/nbinteract.yml +12 -48
- data/lib/starter_web/_data/resources.yml +52 -18
- data/lib/starter_web/_includes/attributes.asciidoc +25 -0
- data/lib/starter_web/_plugins/lunr_index.rb +1 -1
- data/lib/starter_web/assets/images/pages/nbinteract/mandelbrot-menge-1920x1200.jpg +0 -0
- data/lib/starter_web/assets/images/pages/nbinteract/mandelbrot-menge.png +0 -0
- data/lib/starter_web/assets/images/pages/nbinteract/manual/nbi_bar.jpg +0 -0
- data/lib/starter_web/assets/images/pages/nbinteract/manual/nbi_hist.jpg +0 -0
- data/lib/starter_web/assets/images/pages/nbinteract/manual/nbi_line.jpg +0 -0
- data/lib/starter_web/assets/images/pages/nbinteract/manual/nbi_multiple_choice.jpg +0 -0
- data/lib/starter_web/assets/images/pages/nbinteract/manual/nbi_scatter.jpg +0 -0
- data/lib/starter_web/assets/images/pages/nbinteract/manual/nbi_scatter_drag.jpg +0 -0
- data/lib/starter_web/assets/images/pages/nbinteract/manual/nbi_short_answer.jpg +0 -0
- data/lib/starter_web/assets/images/pages/nbinteract/nbi-textbook-example.jpg +0 -0
- data/lib/starter_web/assets/videos/gallery/kick-it-old-school-poster.jpg +0 -0
- data/lib/starter_web/assets/videos/gallery/nye-party-shop-poster.jpg +0 -0
- data/lib/starter_web/assets/videos/gallery/stay-colorful-poster.jpg +0 -0
- data/lib/starter_web/collections/posts/public/series/_posts/2020-01-01-post-wiki-series.adoc +1 -0
- data/lib/starter_web/collections/posts/public/series/_posts/2020-01-02-post-wiki-series.adoc +1 -0
- data/lib/starter_web/collections/posts/public/series/_posts/2020-01-03-post-wiki-series.adoc +1 -0
- data/lib/starter_web/package.json +1 -2
- data/lib/starter_web/pages/public/jupyter/docs/_includes/documents/j1_docs_example_static.asciidoc +232 -232
- data/lib/starter_web/pages/public/jupyter/docs/j1-nbinteract-doc.adoc +165 -149
- data/lib/starter_web/pages/public/jupyter/docs/nbi-widget-manual.adoc +156 -11
- data/lib/starter_web/pages/public/jupyter/docs/nbinteract-doc.adoc +11 -6
- data/lib/starter_web/pages/public/jupyter/examples/j1-circular-times-table.adoc +136 -0
- data/lib/starter_web/pages/public/jupyter/examples/j1-interactive-widgets.adoc +9 -5
- data/lib/starter_web/pages/public/jupyter/examples/j1-odes-in-python.adoc +16 -7
- data/lib/starter_web/pages/public/jupyter/examples/j1-testing-plotly.adoc +95 -0
- data/lib/starter_web/pages/public/jupyter/examples/j1_climate-change-forecast.adoc +4 -4
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/{algebra_with_sympy-checkpoint.ipynb → j1_circular_times_table-checkpoint.ipynb} +5190 -7291
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/j1_climate_change_forecast-checkpoint.ipynb +2 -2
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/j1_docs_example_dynamic-checkpoint.ipynb +1 -1
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/j1_interactive_widgets-checkpoint.ipynb +170 -15
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/j1_ode_selected-checkpoint.ipynb +1 -1
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/j1_odes_in_python-checkpoint.ipynb +520 -111
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/factor_by_factor.mp4 +0 -0
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/{.ipynb_checkpoints/j1_algebra_with_sympy-checkpoint.ipynb → j1_circular_times_table.ipynb} +5178 -7308
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/j1_climate_change_forecast.ipynb +2 -2
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/j1_docs_example_dynamic.ipynb +1 -1
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/j1_interactive_widgets.ipynb +170 -15
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/{j1_ode_selected.ipynb → j1_odes_in_python.ipynb} +783 -34
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/line_by_line.mp4 +0 -0
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/point_by_point.mp4 +0 -0
- data/lib/starter_web/pages/public/jupyter/notebooks/nbi-docs/.ipynb_checkpoints/nbi_docs_recipes_interactive_questions-checkpoint.ipynb +185 -0
- data/lib/starter_web/pages/public/jupyter/notebooks/nbi-docs/.ipynb_checkpoints/nbi_docs_tutorial_interact-checkpoint.ipynb +254 -0
- data/lib/starter_web/pages/public/jupyter/notebooks/nbi-docs/.ipynb_checkpoints/nbi_docs_tutorial_monty_hall-checkpoint.ipynb +732 -0
- data/lib/starter_web/pages/public/jupyter/notebooks/nbi-docs/nbi_docs_recipes_interactive_questions.ipynb +19 -22
- data/lib/starter_web/pages/public/jupyter/notebooks/nbi-docs/nbi_docs_tutorial_monty_hall.ipynb +25 -26
- data/lib/starter_web/pages/public/jupyter/notebooks/textbooks/j1_circular_times_table.html +746 -0
- data/lib/starter_web/pages/public/jupyter/notebooks/textbooks/j1_climate_change_forecast.html +2 -2
- data/lib/starter_web/pages/public/jupyter/notebooks/textbooks/j1_interactive_widgets.html +217 -0
- data/lib/starter_web/pages/public/jupyter/notebooks/textbooks/j1_odes_in_python.html +955 -0
- data/lib/starter_web/pages/public/jupyter/notebooks/textbooks/nbi_docs_recipes_interactive_questions.html +1 -2
- data/lib/starter_web/pages/public/jupyter/{apis/binderhub-api.adoc → services/binderhub.adoc} +25 -28
- data/lib/starter_web/pages/public/jupyter/{apis/jupyterhub-api.adoc → services/jupyterhub.adoc} +8 -9
- data/lib/starter_web/pages/public/learn/roundtrip/100_present_images.adoc +1 -1
- data/lib/starter_web/pages/public/learn/roundtrip/100_present_videos.adoc +9 -15
- data/lib/starter_web/pages/public/learn/roundtrip/200_typography.adoc +1 -1
- data/lib/starter_web/pages/public/learn/roundtrip/300_icon_fonts.adoc +12 -1
- data/lib/starter_web/pages/public/learn/roundtrip/400_asciidoc_extensions.adoc +1 -1
- data/lib/starter_web/pages/public/learn/roundtrip/410_bs_modals_extentions.adoc +1 -1
- data/lib/starter_web/pages/public/learn/roundtrip/420_responsive_tables_extensions.adoc +1 -1
- data/lib/starter_web/pages/public/legal/en/300_privacy.adoc +117 -12
- data/lib/starter_web/pages/public/se/se-fake.adoc +47 -0
- data/lib/starter_web/utilsrv/_defaults/package.json +1 -1
- data/lib/starter_web/utilsrv/package.json +1 -1
- metadata +41 -41
- data/lib/starter_web/_data/_resources.yml +0 -1668
- data/lib/starter_web/assets/images/pages/nbinteract/binderhub-architecture.png +0 -0
- data/lib/starter_web/assets/videos/gallery/adriana-lima-poster.jpg +0 -0
- data/lib/starter_web/pages/public/jupyter/notebooks/binder/binder-launches.ipynb +0 -385
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/Untitled-checkpoint.ipynb +0 -6
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/binder-launches-checkpoint.ipynb +0 -385
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/climate-change-forecast-checkpoint.ipynb +0 -916
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/google_altair-checkpoint.ipynb +0 -33
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/ipympl_test_plots-checkpoint.ipynb +0 -14517
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/j1_altair_interactive-checkpoint.ipynb +0 -16493
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/j1_altair_interactive_test-checkpoint.ipynb +0 -14697
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/j1_altair_visualization-checkpoint.ipynb +0 -15358
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/j1_altair_visualization_full-checkpoint.ipynb +0 -2576
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/j1_climate_change_forecast.ipynb +0 -1060
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/j1_docs_hist-checkpoint.ipynb +0 -98
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/j1_interactive-checkpoint.ipynb +0 -560
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/j1_ipympl_test_plots-checkpoint.ipynb +0 -14511
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/j1_pandas_creating_reading_and_writing-checkpoint.ipynb +0 -328
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/j1_recipes_layout-checkpoint.ipynb +0 -341
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/.ipynb_checkpoints/nbi_docs_recipes_graphing-checkpoint.ipynb +0 -98
- data/lib/starter_web/pages/public/jupyter/notebooks/j1/binder-launches.ipynb +0 -411
- data/lib/starter_web/pages/public/jupyter/notebooks/nbi-docs/.ipynb_checkpoints/nbi_docs_examples_correlation-checkpoint.ipynb +0 -651
- data/lib/starter_web/pages/public/jupyter/notebooks/textbooks/binder-launches.html +0 -546
- data/lib/starter_web/pages/public/jupyter/notebooks/textbooks/j1_ode_selected.html +0 -186
- data/lib/starter_web/pages/public/jupyter/notebooks/themes/altair/excel.py +0 -55
- data/lib/starter_web/pages/public/jupyter/notebooks/themes/altair/ggplot.py +0 -108
- data/lib/starter_web/pages/public/jupyter/notebooks/themes/altair/ggplot2.py +0 -108
- data/lib/starter_web/pages/public/jupyter/notebooks/themes/altair/husky.py +0 -121
- data/lib/starter_web/pages/public/jupyter/notebooks/themes/altair/latimes.py +0 -149
- data/lib/starter_web/pages/public/jupyter/notebooks/themes/altair/pcolor.py +0 -6
- data/lib/starter_web/pages/public/jupyter/notebooks/themes/altair/quartz.py +0 -55
- data/lib/starter_web/pages/public/jupyter/notebooks/themes/altair/spacy_base.py +0 -94
- data/lib/starter_web/pages/public/jupyter/notebooks/themes/altair/spacy_mono.py +0 -158
- data/lib/starter_web/pages/public/jupyter/notebooks/themes/altair/sunsentinel.py +0 -125
@@ -1,385 +0,0 @@
|
|
1
|
-
{
|
2
|
-
"cells": [
|
3
|
-
{
|
4
|
-
"cell_type": "markdown",
|
5
|
-
"metadata": {},
|
6
|
-
"source": [
|
7
|
-
"# Analysing mybinder.org launches\n",
|
8
|
-
"\n",
|
9
|
-
"The first few cells download and massage the data. Later on we answer questions on which repositories are popular and such."
|
10
|
-
]
|
11
|
-
},
|
12
|
-
{
|
13
|
-
"cell_type": "code",
|
14
|
-
"execution_count": 1,
|
15
|
-
"metadata": {},
|
16
|
-
"outputs": [],
|
17
|
-
"source": [
|
18
|
-
"%matplotlib inline\n",
|
19
|
-
"\n",
|
20
|
-
"import matplotlib.pyplot as plt\n",
|
21
|
-
"import datetime\n",
|
22
|
-
"import pandas as pd"
|
23
|
-
]
|
24
|
-
},
|
25
|
-
{
|
26
|
-
"cell_type": "code",
|
27
|
-
"execution_count": 2,
|
28
|
-
"metadata": {},
|
29
|
-
"outputs": [],
|
30
|
-
"source": [
|
31
|
-
"index = pd.read_json(\"https://archive.analytics.mybinder.org/index.jsonl\",\n",
|
32
|
-
" lines=True)"
|
33
|
-
]
|
34
|
-
},
|
35
|
-
{
|
36
|
-
"cell_type": "code",
|
37
|
-
"execution_count": null,
|
38
|
-
"metadata": {},
|
39
|
-
"outputs": [],
|
40
|
-
"source": [
|
41
|
-
"# get all days since start of 2019\n",
|
42
|
-
"now = datetime.datetime.now()\n",
|
43
|
-
"n = (now - datetime.datetime(2019, 1, 1)).days\n",
|
44
|
-
"\n",
|
45
|
-
"# small range for previewing\n",
|
46
|
-
"#n = 30\n",
|
47
|
-
"\n",
|
48
|
-
"frames = []\n",
|
49
|
-
"for idx, day in index.sort_index(ascending=False).iterrows():\n",
|
50
|
-
" df = pd.read_json(\"https://archive.analytics.mybinder.org/{}\".format(day['name']),\n",
|
51
|
-
" lines=True, )\n",
|
52
|
-
" frames.append(df)\n",
|
53
|
-
" if len(frames) > n:\n",
|
54
|
-
" break\n",
|
55
|
-
" \n",
|
56
|
-
"print(f\"Fetched data for {n} days.\")"
|
57
|
-
]
|
58
|
-
},
|
59
|
-
{
|
60
|
-
"cell_type": "code",
|
61
|
-
"execution_count": null,
|
62
|
-
"metadata": {},
|
63
|
-
"outputs": [],
|
64
|
-
"source": [
|
65
|
-
"df = pd.concat(frames)"
|
66
|
-
]
|
67
|
-
},
|
68
|
-
{
|
69
|
-
"cell_type": "code",
|
70
|
-
"execution_count": null,
|
71
|
-
"metadata": {},
|
72
|
-
"outputs": [],
|
73
|
-
"source": [
|
74
|
-
"# make it easier to grab the ref\n",
|
75
|
-
"def get_repo(spec):\n",
|
76
|
-
" s = spec.rsplit(\"/\", 1)[0]\n",
|
77
|
-
" if s.endswith('.git'):\n",
|
78
|
-
" s = s[:-4]\n",
|
79
|
-
" return s\n",
|
80
|
-
"df['repo'] = df['spec'].apply(get_repo) #lambda s: s.rsplit(\"/\", 1)[0].replace(\".git\", \"\"))\n",
|
81
|
-
"df['org'] = df['spec'].apply(lambda s: s.split(\"/\", 1)[0])\n",
|
82
|
-
"df['ref'] = df['spec'].apply(lambda s: s.rsplit(\"/\", 1)[1])"
|
83
|
-
]
|
84
|
-
},
|
85
|
-
{
|
86
|
-
"cell_type": "code",
|
87
|
-
"execution_count": null,
|
88
|
-
"metadata": {},
|
89
|
-
"outputs": [],
|
90
|
-
"source": [
|
91
|
-
"# take a look at the data, does it look sensible?\n",
|
92
|
-
"df.sample(10)"
|
93
|
-
]
|
94
|
-
},
|
95
|
-
{
|
96
|
-
"cell_type": "code",
|
97
|
-
"execution_count": null,
|
98
|
-
"metadata": {},
|
99
|
-
"outputs": [],
|
100
|
-
"source": [
|
101
|
-
"df = df.drop(columns=['schema', 'version', 'spec', 'status'])"
|
102
|
-
]
|
103
|
-
},
|
104
|
-
{
|
105
|
-
"cell_type": "code",
|
106
|
-
"execution_count": null,
|
107
|
-
"metadata": {},
|
108
|
-
"outputs": [],
|
109
|
-
"source": [
|
110
|
-
"df.head()"
|
111
|
-
]
|
112
|
-
},
|
113
|
-
{
|
114
|
-
"cell_type": "markdown",
|
115
|
-
"metadata": {},
|
116
|
-
"source": [
|
117
|
-
"## Monthly, weekly, daily active repos"
|
118
|
-
]
|
119
|
-
},
|
120
|
-
{
|
121
|
-
"cell_type": "code",
|
122
|
-
"execution_count": null,
|
123
|
-
"metadata": {},
|
124
|
-
"outputs": [],
|
125
|
-
"source": [
|
126
|
-
"df_ = df.set_index(\"timestamp\")"
|
127
|
-
]
|
128
|
-
},
|
129
|
-
{
|
130
|
-
"cell_type": "code",
|
131
|
-
"execution_count": null,
|
132
|
-
"metadata": {},
|
133
|
-
"outputs": [],
|
134
|
-
"source": [
|
135
|
-
"def n_active_repos(period=30):\n",
|
136
|
-
" \"\"\"Unique active repos over the period\n",
|
137
|
-
" \n",
|
138
|
-
" With period=30 this gives monthly active repos\n",
|
139
|
-
" With period=1 you get daily active repos\n",
|
140
|
-
" \"\"\"\n",
|
141
|
-
" now = datetime.datetime.now()\n",
|
142
|
-
" start = datetime.datetime(2019, 1, 1)\n",
|
143
|
-
" days_since_start = (now - start).days\n",
|
144
|
-
"\n",
|
145
|
-
" data = []\n",
|
146
|
-
"\n",
|
147
|
-
" for n in range(days_since_start):\n",
|
148
|
-
" s = start + datetime.timedelta(days=n)\n",
|
149
|
-
" e = start + datetime.timedelta(days=n+period)\n",
|
150
|
-
" if e > now:\n",
|
151
|
-
" break\n",
|
152
|
-
"\n",
|
153
|
-
" # our \"monthly\" data\n",
|
154
|
-
" monthly = df_.loc[s.isoformat():e.isoformat()]\n",
|
155
|
-
" data.append(dict(timestamp=e, repos=len(set(monthly.repo))))\n",
|
156
|
-
" \n",
|
157
|
-
" return pd.DataFrame.from_records(data).set_index(\"timestamp\")"
|
158
|
-
]
|
159
|
-
},
|
160
|
-
{
|
161
|
-
"cell_type": "code",
|
162
|
-
"execution_count": null,
|
163
|
-
"metadata": {},
|
164
|
-
"outputs": [],
|
165
|
-
"source": [
|
166
|
-
"monthly_active = n_active_repos(30)\n",
|
167
|
-
"weekly_active = n_active_repos(7)\n",
|
168
|
-
"daily_active = n_active_repos(1)"
|
169
|
-
]
|
170
|
-
},
|
171
|
-
{
|
172
|
-
"cell_type": "code",
|
173
|
-
"execution_count": null,
|
174
|
-
"metadata": {},
|
175
|
-
"outputs": [],
|
176
|
-
"source": [
|
177
|
-
"activity = pd.merge(monthly_active, daily_active,\n",
|
178
|
-
" suffixes=(\"_monthly\", \"_daily\"), left_index=True, right_index=True)\n",
|
179
|
-
"activity = pd.merge(activity, weekly_active, left_index=True, right_index=True)\n",
|
180
|
-
"\n",
|
181
|
-
"activity.columns = ['30day active', '1d active', '7d active']\n",
|
182
|
-
"activity.plot();"
|
183
|
-
]
|
184
|
-
},
|
185
|
-
{
|
186
|
-
"cell_type": "markdown",
|
187
|
-
"metadata": {},
|
188
|
-
"source": [
|
189
|
-
"## Total launches"
|
190
|
-
]
|
191
|
-
},
|
192
|
-
{
|
193
|
-
"cell_type": "code",
|
194
|
-
"execution_count": null,
|
195
|
-
"metadata": {},
|
196
|
-
"outputs": [],
|
197
|
-
"source": [
|
198
|
-
"# Sneak peek: total launches!\n",
|
199
|
-
"df.shape"
|
200
|
-
]
|
201
|
-
},
|
202
|
-
{
|
203
|
-
"cell_type": "markdown",
|
204
|
-
"metadata": {},
|
205
|
-
"source": [
|
206
|
-
"## Launches per day"
|
207
|
-
]
|
208
|
-
},
|
209
|
-
{
|
210
|
-
"cell_type": "code",
|
211
|
-
"execution_count": null,
|
212
|
-
"metadata": {},
|
213
|
-
"outputs": [],
|
214
|
-
"source": [
|
215
|
-
"daily = df.set_index(\"timestamp\").resample('D').count()"
|
216
|
-
]
|
217
|
-
},
|
218
|
-
{
|
219
|
-
"cell_type": "code",
|
220
|
-
"execution_count": null,
|
221
|
-
"metadata": {},
|
222
|
-
"outputs": [],
|
223
|
-
"source": [
|
224
|
-
"daily['repo'].plot()"
|
225
|
-
]
|
226
|
-
},
|
227
|
-
{
|
228
|
-
"cell_type": "markdown",
|
229
|
-
"metadata": {},
|
230
|
-
"source": [
|
231
|
-
"## Estimate number of unique repositories\n",
|
232
|
-
"\n",
|
233
|
-
"Expect the raw number of launches to be bigger than the number of repositories launched more than once. Those launched only once might have been accidents."
|
234
|
-
]
|
235
|
-
},
|
236
|
-
{
|
237
|
-
"cell_type": "code",
|
238
|
-
"execution_count": null,
|
239
|
-
"metadata": {
|
240
|
-
"scrolled": true
|
241
|
-
},
|
242
|
-
"outputs": [],
|
243
|
-
"source": [
|
244
|
-
"len(set(df.repo))"
|
245
|
-
]
|
246
|
-
},
|
247
|
-
{
|
248
|
-
"cell_type": "code",
|
249
|
-
"execution_count": null,
|
250
|
-
"metadata": {},
|
251
|
-
"outputs": [],
|
252
|
-
"source": [
|
253
|
-
"from collections import Counter\n",
|
254
|
-
"\n",
|
255
|
-
"sum(1 for k,v in Counter(df.repo).items() if v > 3)"
|
256
|
-
]
|
257
|
-
},
|
258
|
-
{
|
259
|
-
"cell_type": "markdown",
|
260
|
-
"metadata": {},
|
261
|
-
"source": [
|
262
|
-
"## Popular repositories and their branches\n",
|
263
|
-
"\n",
|
264
|
-
"Twenty most popular repos:"
|
265
|
-
]
|
266
|
-
},
|
267
|
-
{
|
268
|
-
"cell_type": "code",
|
269
|
-
"execution_count": null,
|
270
|
-
"metadata": {},
|
271
|
-
"outputs": [],
|
272
|
-
"source": [
|
273
|
-
"top20 = df.groupby(\"repo\").count().sort_values(\"timestamp\", ascending=False).head(20)\n",
|
274
|
-
"top20"
|
275
|
-
]
|
276
|
-
},
|
277
|
-
{
|
278
|
-
"cell_type": "code",
|
279
|
-
"execution_count": null,
|
280
|
-
"metadata": {},
|
281
|
-
"outputs": [],
|
282
|
-
"source": [
|
283
|
-
"print(\"Cumulative top20 launches:\", top20['ref'].sum())\n",
|
284
|
-
"print(\"The top20 repos are {:.1f}% of all \"\n",
|
285
|
-
" \"launches.\".format(100 * top20['ref'].sum() / df.shape[0]))"
|
286
|
-
]
|
287
|
-
},
|
288
|
-
{
|
289
|
-
"cell_type": "markdown",
|
290
|
-
"metadata": {},
|
291
|
-
"source": [
|
292
|
-
"## Per org stats\n",
|
293
|
-
"\n",
|
294
|
-
"Needs more RAM than mybinder.org gives us for now"
|
295
|
-
]
|
296
|
-
},
|
297
|
-
{
|
298
|
-
"cell_type": "code",
|
299
|
-
"execution_count": null,
|
300
|
-
"metadata": {},
|
301
|
-
"outputs": [],
|
302
|
-
"source": [
|
303
|
-
"# add a new column showing total launches per repo\n",
|
304
|
-
"totals_per_repo = (df.groupby([\"repo\"])\n",
|
305
|
-
" .size()\n",
|
306
|
-
" .reset_index(name='repo_counts'))"
|
307
|
-
]
|
308
|
-
},
|
309
|
-
{
|
310
|
-
"cell_type": "code",
|
311
|
-
"execution_count": null,
|
312
|
-
"metadata": {},
|
313
|
-
"outputs": [],
|
314
|
-
"source": [
|
315
|
-
"# add a nnew column showing total launches per org\n",
|
316
|
-
"totals_per_org = (df.groupby([\"org\"])\n",
|
317
|
-
" .size()\n",
|
318
|
-
" .reset_index(name='org_counts'))"
|
319
|
-
]
|
320
|
-
},
|
321
|
-
{
|
322
|
-
"cell_type": "code",
|
323
|
-
"execution_count": null,
|
324
|
-
"metadata": {},
|
325
|
-
"outputs": [],
|
326
|
-
"source": [
|
327
|
-
"df_ = pd.merge(df, totals_per_repo, on='repo')\n",
|
328
|
-
"df_ = pd.merge(df_, totals_per_org, on='org')\n",
|
329
|
-
"#df_.sample(10)"
|
330
|
-
]
|
331
|
-
},
|
332
|
-
{
|
333
|
-
"cell_type": "code",
|
334
|
-
"execution_count": null,
|
335
|
-
"metadata": {},
|
336
|
-
"outputs": [],
|
337
|
-
"source": [
|
338
|
-
"(df.groupby(\"provider\")\n",
|
339
|
-
" .size()\n",
|
340
|
-
" .reset_index(name='Launches')\n",
|
341
|
-
" .sort_values('Launches', ascending=False))"
|
342
|
-
]
|
343
|
-
},
|
344
|
-
{
|
345
|
-
"cell_type": "code",
|
346
|
-
"execution_count": null,
|
347
|
-
"metadata": {
|
348
|
-
"scrolled": false
|
349
|
-
},
|
350
|
-
"outputs": [],
|
351
|
-
"source": [
|
352
|
-
"(df_.groupby([\"org\", \"repo\", \"ref\", \"repo_counts\", \"org_counts\"])\n",
|
353
|
-
" .size()\n",
|
354
|
-
" # give the column a nice name\n",
|
355
|
-
" .reset_index(name='ref_counts')\n",
|
356
|
-
" # sort first by total launches, then within a repo by ref launches\n",
|
357
|
-
" .sort_values(['org_counts', 'repo_counts', 'ref_counts'],\n",
|
358
|
-
" ascending=[False,False, False])\n",
|
359
|
-
" .set_index([\"org\", 'repo', 'ref'])\n",
|
360
|
-
")"
|
361
|
-
]
|
362
|
-
}
|
363
|
-
],
|
364
|
-
"metadata": {
|
365
|
-
"kernelspec": {
|
366
|
-
"display_name": "Python 3",
|
367
|
-
"language": "python",
|
368
|
-
"name": "python3"
|
369
|
-
},
|
370
|
-
"language_info": {
|
371
|
-
"codemirror_mode": {
|
372
|
-
"name": "ipython",
|
373
|
-
"version": 3
|
374
|
-
},
|
375
|
-
"file_extension": ".py",
|
376
|
-
"mimetype": "text/x-python",
|
377
|
-
"name": "python",
|
378
|
-
"nbconvert_exporter": "python",
|
379
|
-
"pygments_lexer": "ipython3",
|
380
|
-
"version": "3.7.9"
|
381
|
-
}
|
382
|
-
},
|
383
|
-
"nbformat": 4,
|
384
|
-
"nbformat_minor": 2
|
385
|
-
}
|