Skip to content

Instantly share code, notes, and snippets.

@sacundim
Last active September 28, 2020 16:49
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save sacundim/0990e827b092c08ccc6d3e4ecb53915d to your computer and use it in GitHub Desktop.
Save sacundim/0990e827b092c08ccc6d3e4ecb53915d to your computer and use it in GitHub Desktop.
Búsqueda de SQL (Postgres) para calcular el Covímetro a partir de mi base de datos de COVID-19 en Puerto Rico.
bulletin_date datum_date confirmed_cases sum_a sum_b covimetro
2020-09-27 2020-09-23 77 15616.000000000000
2020-09-27 2020-09-22 138 15672.000000000000 15584.857142857143 0.00559150824059984045
2020-09-27 2020-09-21 209 15657.857142857143 15522.285714285714 0.00873398615815052107
2020-09-27 2020-09-20 30 15798.285714285714 15598.857142857143 0.01278481940068866755
2020-09-27 2020-09-19 79 15902.857142857143 15616.285714285714 0.01835080593519588558
2020-09-27 2020-09-18 359 15921.285714285714 15597.285714285714 0.02077284509209477878
2020-09-27 2020-09-17 504 15889.285714285714 15528.142857142857 0.02325731160933603525
2020-09-27 2020-09-16 687 15849.142857142857 15487.285714285714 0.02336478770604459923
2020-09-27 2020-09-15 400 15551.285714285714 15179.571428571429 0.02448779845092553833
2020-09-27 2020-09-14 469 15275.571428571429 14877.000000000000 0.02679111572033534987
2020-09-27 2020-09-13 35 15153.000000000000 14738.000000000000 0.02815850183199891437
2020-09-27 2020-09-12 148 15075.000000000000 14694.714285714286 0.02587908188561482699
2020-09-27 2020-09-11 547 15116.714285714286 14740.571428571429 0.02551752209644905144
2020-09-27 2020-09-10 619 15105.571428571429 14780.571428571429 0.02198832444135158059
2020-09-27 2020-09-09 444 15237.571428571429 14912.714285714286 0.02178390443437527859
2020-09-27 2020-09-08 371 14960.714285714286 14642.714285714286 0.02171728504668338185
2020-09-27 2020-09-07 111 14771.714285714286 14495.428571428571 0.01906019631805106100
2020-09-27 2020-09-06 34 14819.428571428571 14587.285714285714 0.01591405431344320428
2020-09-27 2020-09-05 100 14827.285714285714 14620.000000000000 0.01417822943130738714
2020-09-27 2020-09-04 255 14834.000000000000 14643.285714285714 0.01302400905339357898
2020-09-27 2020-09-03 310 14886.285714285714 14677.428571428571 0.01422981838001986571
2020-09-27 2020-09-02 270 14876.428571428571 14668.571428571429 0.01417023763147637278
2020-09-27 2020-09-01 255 14683.571428571429 14478.000000000000 0.01419888303435757701
2020-09-27 2020-08-31 238 14492.000000000000 14295.714285714286 0.01373038872789045641
2020-09-27 2020-08-30 27 14438.714285714286 14259.428571428571 0.01257313456760444255
2020-09-27 2020-08-29 84 14378.428571428571 14210.142857142857 0.01184264760583484646
2020-09-27 2020-08-28 190 14290.142857142857 14118.857142857143 0.01213169823538932722
2020-09-27 2020-08-27 191 14207.857142857143 14027.285714285714 0.01287287022232183220
2020-09-27 2020-08-26 193 14112.285714285714 13929.857142857143 0.01309622701494217956
2020-09-27 2020-08-25 276 13932.857142857143 13758.142857142857 0.01269897307568506975
2020-09-27 2020-08-24 303 13771.142857142857 13585.857142857143 0.01363813209114518235
2020-09-27 2020-08-23 40 13629.857142857143 13427.142857142857 0.01509735078199810634
2020-09-27 2020-08-22 30 13476.142857142857 13240.285714285714 0.01781359918862347636
2020-09-27 2020-08-21 264 13271.285714285714 13028.714285714286 0.01861821690551634261
2020-09-27 2020-08-20 313 13072.714285714286 12815.571428571429 0.02006487643380261668
2020-09-27 2020-08-19 425 12843.571428571429 12588.285714285714 0.02027962504823083865
2020-09-27 2020-08-18 323 12588.285714285714 12310.000000000000 0.02260647557154459789
2020-09-27 2020-08-17 405 12314.000000000000 12012.571428571429 0.02509275996575012992
2020-09-27 2020-08-16 27 12027.571428571429 11718.285714285714 0.02639342663480768826
2020-09-27 2020-08-15 191 11739.285714285714 11430.571428571429 0.02700777363961300421
2020-09-27 2020-08-14 426 11444.571428571429 11125.1428571428571429 0.02871231188042533001
2020-09-27 2020-08-13 368 11146.1428571428571429 10826.2857142857142857 0.02954449488018579120
2020-09-27 2020-08-12 421 10843.2857142857142857 10521.5714285714285714 0.03057663847062497454
2020-09-27 2020-08-11 398 10528.5714285714285714 10210.2857142857142857 0.03117304678755316767
2020-09-27 2020-08-10 408 10222.2857142857142857 9901.2857142857142857 0.03242003203047223304
2020-09-27 2020-08-09 40 9918.2857142857142857 9596.2857142857142857 0.03355464912019531366
2020-09-27 2020-08-08 167 9608.2857142857142857 9291.2857142857142857 0.03411799074401512938
2020-09-27 2020-08-07 445 9305.2857142857142857 8978.1428571428571429 0.03643769790125224752
2020-09-27 2020-08-06 375 8990.1428571428571429 8661.8571428571428571 0.03790015338182178023
2020-09-27 2020-08-05 386 8673.8571428571428571 8344.8571428571428571 0.03942548019310439278
2020-09-27 2020-08-04 469 8346.8571428571428571 8025.5714285714285714 0.04003275245198383738
2020-09-27 2020-08-03 416 8030.5714285714285714 7720.4285714285714286 0.04017171511574116906
2020-09-27 2020-08-02 45 7730.4285714285714286 7461.0000000000000000 0.03611158979072127444
2020-09-27 2020-08-01 113 7472.0000000000000000 7220.7142857142857143 0.03480067266791967553
2020-09-27 2020-07-31 367 7229.7142857142857143 7003.2857142857142857 0.03233176264202517186
2020-09-27 2020-07-30 90 7020.2857142857142857 6809.7142857142857143 0.03092221196609885038
2020-09-27 2020-07-29 259 6835.7142857142857143 6623.5714285714285714 0.03202846975088967972
2020-09-27 2020-07-28 295 6624.5714285714285714 6418.1428571428571429 0.03216328711020099271
2020-09-27 2020-07-27 305 6420.1428571428571429 6226.7142857142857143 0.03106430816527863813
2020-09-27 2020-07-26 56 6255.7142857142857143 6031.7142857142857143 0.03713703756335559661
2020-09-27 2020-07-25 73 6050.7142857142857143 5820.1428571428571429 0.03961611153383569377
2020-09-27 2020-07-24 276 5828.1428571428571429 5598.0000000000000000 0.04111162149747358751
2020-09-27 2020-07-23 304 5604.0000000000000000 5371.5714285714285714 0.04327012579452674132
2020-09-27 2020-07-22 305 5376.5714285714285714 5143.0000000000000000 0.04541540512763534346
2020-09-27 2020-07-21 292 5145.0000000000000000 4908.1428571428571429 0.04825799691474808626
2020-09-27 2020-07-20 321 4911.1428571428571429 4674.2857142857142857 0.05067237163814180930
2020-09-27 2020-07-19 64 4683.2857142857142857 4441.7142857142857143 0.05438698057378103692
2020-09-27 2020-07-18 96 4447.7142857142857143 4189.4285714285714286 0.06165177658050876355
2020-09-27 2020-07-17 276 4203.4285714285714286 3934.7142857142857143 0.06829321424681407254
2020-09-27 2020-07-16 337 3942.7142857142857143 3654.5714285714285714 0.07884450003908998516
2020-09-27 2020-07-15 422 3661.5714285714285714 3375.7142857142857143 0.08468049090139652982
2020-09-27 2020-07-14 365 3377.7142857142857143 3087.1428571428571429 0.09412309116149930587
2020-09-27 2020-07-13 457 3089.1428571428571429 2791.7142857142857143 0.10653976051581209703
2020-09-27 2020-07-12 48 2802.7142857142857143 2519.1428571428571429 0.11256663264148803447
2020-09-27 2020-07-11 129 2528.1428571428571429 2274.2857142857142857 0.11162060301507537691
2020-09-27 2020-07-10 324 2284.2857142857142857 2047.8571428571428571 0.11545169166376002792
2020-09-27 2020-07-09 240 2061.8571428571428571 1862.2857142857142857 0.10716477447069653266
2020-09-27 2020-07-08 214 1878.2857142857142857 1683.4285714285714286 0.11575016972165648334
2020-09-27 2020-07-07 243 1683.4285714285714286 1505.0000000000000000 0.11855719031798766020
2020-09-27 2020-07-06 199 1509.0000000000000000 1356.4285714285714286 0.11248025276461295416
2020-09-27 2020-07-05 15 1381.4285714285714286 1246.1428571428571429 0.10856356757996102257
2020-09-27 2020-07-04 14 1263.1428571428571429 1147.0000000000000000 0.10125793996761738701
2020-09-27 2020-07-03 143 1166.0000000000000000 1071.8571428571428571 0.08783153405304544853
2020-09-27 2020-07-02 119 1094.8571428571428571 1017.0000000000000000 0.07655569602472257335
2020-09-27 2020-07-01 80 1025.0000000000000000 948.8571428571428571 0.08024691358024691363
2020-09-27 2020-06-30 89 951.8571428571428571 875.8571428571428571 0.08677214157559941282
2020-09-27 2020-06-29 85 881.8571428571428571 820.0000000000000000 0.07543554006968641110
2020-09-27 2020-06-28 3 830.0000000000000000 778.1428571428571429 0.06664218836056544881
2020-09-27 2020-06-27 13 800.1428571428571429 755.2857142857142857 0.05939095895592963881
2020-09-27 2020-06-26 44 774.2857142857142857 735.8571428571428571 0.05222286934575810526
2020-09-27 2020-06-25 49 751.8571428571428571 721.5714285714285714 0.04197188675509800038
2020-09-27 2020-06-24 31
2020-09-27 2020-06-23 44
2020-09-27 2020-06-22 28
2020-09-27 2020-06-21
2020-09-27 2020-06-20 4
2020-09-27 2020-06-19 15
2020-09-27 2020-06-18 21 674.4285714285714286
2020-09-27 2020-06-17 14 694.4285714285714286 680.2857142857142857 0.02078958420831583375
2020-09-27 2020-06-16 21 682.2857142857142857 667.0000000000000000 0.02291711287213536087
2020-09-27 2020-06-15 17 676.0000000000000000 660.4285714285714286 0.02357776335712740640
2020-09-27 2020-06-14 7 682.4285714285714286 668.1428571428571429 0.02138122728244601238
2020-09-27 2020-06-13 12 694.1428571428571429 679.8571428571428571 0.02101281781886951053
2020-09-27 2020-06-12 17 711.8571428571428571 698.8571428571428571 0.01860179885527391660
2020-09-27 2020-06-11 12 722.8571428571428571 710.5714285714285714 0.01728990751909931643
2020-09-27 2020-06-10 14 738.5714285714285714 727.0000000000000000 0.01591668304185498129
2020-09-27 2020-06-09 12 731.0000000000000000 720.4285714285714286 0.01467380527463811219
2020-09-27 2020-06-08 12 732.4285714285714286 722.8571428571428571 0.01324110671936758903
2020-09-27 2020-06-07 2 725.8571428571428571 716.4285714285714286 0.01316051844466600189
2020-09-27 2020-06-06 5 751.4285714285714286 742.7142857142857143 0.01173302558184266207
2020-09-27 2020-06-05 10 769.7142857142857143 760.2857142857142857 0.01240135287485907557
2020-09-27 2020-06-04 11 795.2857142857142857 783.8571428571428571 0.01457991616548204852
2020-09-27 2020-06-03 9 833.8571428571428571 822.5714285714285714 0.01372004168113928446
2020-09-27 2020-06-02 17 825.5714285714285714 814.7142857142857143 0.01332631948097492542
2020-09-27 2020-06-01 26 829.7142857142857143 816.1428571428571429 0.01662874146683003672
2020-09-27 2020-05-31 1 866.1428571428571429 851.4285714285714286 0.01728187919463087250
2020-09-27 2020-05-30 2 904.4285714285714286 889.8571428571428571 0.01637502006742655330
2020-09-27 2020-05-29 29 963.8571428571428571 950.8571428571428571 0.01367187500000000000
2020-09-27 2020-05-28 19 1006.8571428571428571 996.8571428571428571 0.01003152765835482946
2020-09-27 2020-05-27 8 1081.8571428571428571 1071.7142857142857143 0.00946414289522793916
2020-09-27 2020-05-26 6 1083.7142857142857143 1073.4285714285714286 0.00958211338834176203
2020-09-27 2020-05-25 5 1097.4285714285714286 1090.0000000000000000 0.00681520314547837486
2020-09-27 2020-05-24 2 1139.0000000000000000 1133.4285714285714286 0.00491555331484749178
2020-09-27 2020-05-23 3 1192.4285714285714286 1186.0000000000000000 0.00542038063117321130
2020-09-27 2020-05-22 9 1228.0000000000000000 1221.2857142857142857 0.00549771903146566851
2020-09-27 2020-05-21 6 1269.2857142857142857 1262.2857142857142857 0.00554549569941149842
2020-09-27 2020-05-20 14 1296.2857142857142857 1289.2857142857142857 0.00542936288088642659
2020-09-27 2020-05-19 8 1299.2857142857142857 1292.4285714285714286 0.00530562617442246045
2020-09-27 2020-05-18 7 1304.4285714285714286 1297.2857142857142857 0.00550600154168043170
2020-09-27 2020-05-17 2 1311.2857142857142857 1303.7142857142857143 0.00580758273065965371
2020-09-27 2020-05-16 2 1308.7142857142857143 1301.7142857142857143 0.00537752414398595259
2020-09-27 2020-05-15 11 1306.7142857142857143 1298.8571428571428571 0.00604927408710954690
2020-09-27 2020-05-14 9 1305.8571428571428571 1296.7142857142857143 0.00705078770518893903
2020-09-27 2020-05-13 10
2020-09-27 2020-05-12 14
2020-09-27 2020-05-11 16
2020-09-27 2020-05-10
2020-09-27 2020-05-09 4
2020-09-27 2020-05-08 25
2020-09-27 2020-05-07 17 1228.1428571428571429
2020-09-27 2020-05-06 19 1230.1428571428571429 1216.0000000000000000 0.01163063909774436094
2020-09-27 2020-05-05 23 1216.0000000000000000 1201.5714285714285714 0.01200808465105219358
2020-09-27 2020-05-04 8 1201.5714285714285714 1189.2857142857142857 0.01033033033033033032
2020-09-27 2020-05-03 3 1189.2857142857142857 1176.2857142857142857 0.01105173670148166140
2020-09-27 2020-05-02 6 1176.2857142857142857 1163.2857142857142857 0.01117524253960456834
2020-09-27 2020-05-01 10 1163.2857142857142857 1151.2857142857142857 0.01042312942052363817
2020-09-27 2020-04-30 22 1151.2857142857142857 1138.1428571428571429 0.01154763399020961461
2020-09-27 2020-04-29 19 1138.1428571428571429 1125.0000000000000000 0.01168253968253968258
2020-09-27 2020-04-28 16 1125.0000000000000000 1112.5714285714285714 0.01117103235747303547
2020-09-27 2020-04-27 16 1112.5714285714285714 1099.1428571428571429 0.01221731219131790999
2020-09-27 2020-04-26 3 1099.1428571428571429 1086.4285714285714286 0.01170282708744247207
2020-09-27 2020-04-25 1 1086.4285714285714286 1072.4285714285714286 0.01305448248301585187
2020-09-27 2020-04-24 17 1072.4285714285714286 1057.8571428571428571 0.01377447670492910203
2020-09-27 2020-04-23 17 1057.8571428571428571 1042.7142857142857143 0.01452253733388135356
2020-09-27 2020-04-22 28 1042.7142857142857143 1027.7142857142857143 0.01459549624687239366
2020-09-27 2020-04-21 20 1027.7142857142857143 1011.5714285714285714 0.01595819799463352638
2020-09-27 2020-04-20 20 1011.5714285714285714 994.7142857142857143 0.01694671836851931634
2020-09-27 2020-04-19 2 994.7142857142857143 976.5714285714285714 0.01857811585722644826
2020-09-27 2020-04-18 9 976.5714285714285714 957.8571428571428571 0.01953765846383296049
2020-09-27 2020-04-17 22 957.8571428571428571 938.5714285714285714 0.02054794520547945204
2020-09-27 2020-04-16 26 938.5714285714285714 918.1428571428571429 0.02224988330480784184
2020-09-27 2020-04-15 32 918.1428571428571429 897.4285714285714286 0.02308182107609041708
2020-09-27 2020-04-14 24 897.4285714285714286 876.2857142857142857 0.02412781219432670367
2020-09-27 2020-04-13 28 876.2857142857142857 857.8571428571428571 0.02148209825145711910
2020-09-27 2020-04-12 4 857.8571428571428571 838.1428571428571429 0.02352139083006647339
2020-09-27 2020-04-11 12 838.1428571428571429 819.1428571428571429 0.02319497732821764911
2020-09-27 2020-04-10 3 819.1428571428571429 798.5714285714285714 0.02576028622540250456
2020-09-27 2020-04-09 35 798.5714285714285714 774.8571428571428571 0.03060471976401179943
2020-09-27 2020-04-08 27 774.8571428571428571 751.2857142857142857 0.03137478608100399312
2020-09-27 2020-04-07 35 751.2857142857142857 727.2857142857142857 0.03299941072480848556
2020-09-27 2020-04-06 50 727.2857142857142857 696.5714285714285714 0.04409351927809680068
2020-09-27 2020-04-05 3 696.5714285714285714 663.2857142857142857 0.05018307129011415031
2020-09-27 2020-04-04 15 663.2857142857142857 623.2857142857142857 0.06417602567041026817
2020-09-27 2020-04-03 50 623.2857142857142857 580.2857142857142857 0.07410142786804529788
2020-09-27 2020-04-02 53 580.2857142857142857 532.2857142857142857 0.09017713365539452496
2020-09-27 2020-04-01 74 532.2857142857142857 483.0000000000000000 0.10204081632653061222
2020-09-27 2020-03-31 56 483.0000000000000000 432.4285714285714286 0.11694747274529236861
2020-09-27 2020-03-30 85 432.4285714285714286 382.0000000000000000 0.13201196709050112199
2020-09-27 2020-03-29 12 382.0000000000000000 330.7142857142857143 0.15507559395248380125
2020-09-27 2020-03-28 24 330.7142857142857143 284.0000000000000000 0.16448692152917505035
2020-09-27 2020-03-27 49 284.0000000000000000 238.4285714285714286 0.19113241461953265414
2020-09-27 2020-03-26 59 238.4285714285714286 200.1428571428571429 0.19129193433261955735
2020-09-27 2020-03-25 42 200.1428571428571429 162.1428571428571429 0.23436123348017621139
2020-09-27 2020-03-24 48 162.1428571428571429 125.8571428571428571 0.28830874006810442757
2020-09-27 2020-03-23 34 125.8571428571428571 94.5714285714285714 0.33081570996978851959
2020-09-27 2020-03-22 10 94.5714285714285714 71.0000000000000000 0.33199195171026156901
2020-09-27 2020-03-21 12 71.0000000000000000 52.7142857142857143 0.34688346883468834652
2020-09-27 2020-03-20 14 52.7142857142857143 40.2857142857142857 0.30851063829787234124
2020-09-27 2020-03-19 5 40.2857142857142857 31.4285714285714286 0.28181818181818181656
WITH terms AS (
SELECT
bulletin_date,
datum_date,
sum(confirmed_cases) OVER older AS old_sum,
lag(confirmed_cases, 3) OVER current AS lag3,
lag(confirmed_cases, 2) OVER current AS lag2,
lag(confirmed_cases, 1) OVER current AS lag1,
confirmed_cases,
lead(confirmed_cases, 1) OVER current AS lead1,
lead(confirmed_cases, 2) OVER current AS lead2,
lead(confirmed_cases, 3) OVER current AS lead3
FROM bitemporal
WINDOW older AS (
PARTITION BY bulletin_date
ORDER BY datum_date
RANGE BETWEEN '58 day' PRECEDING
AND '4 day' PRECEDING
), current AS (
PARTITION BY bulletin_date
ORDER BY datum_date
RANGE BETWEEN '3 day' PRECEDING
AND '3 day' FOLLOWING
)
), sums AS (
SELECT
bulletin_date,
datum_date,
confirmed_cases,
(7 * (old_sum + lag3)
+ 6 * lag2
+ 5 * lag1
+ 4 * confirmed_cases
+ 3 * lead1
+ 2 * lead2
+ lead3) / 7.0
AS sum_a,
(7 * old_sum
+ 6 * lag3
+ 5 * lag2
+ 4 * lag1
+ 3 * confirmed_cases
+ 2 * lead1
+ lead2) / 7.0
AS sum_b
FROM terms
)
SELECT
bulletin_date,
datum_date,
confirmed_cases,
sum_a,
sum_b,
(sum_a - sum_b) / sum_b
AS covimetro
FROM sums
ORDER BY bulletin_date DESC, datum_date DESC;
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment