sapor 0.3.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/Area Class Diagram.dia +0 -0
- data/Area Class Diagram.png +0 -0
- data/Class Diagram.dia +0 -0
- data/Class Diagram.png +0 -0
- data/Example-Catalonia.md +361 -0
- data/Example-Flanders.md +486 -0
- data/Example-Greece.md +25 -0
- data/Example-Oslo.md +678 -0
- data/Example-UnitedKingdom-Referendum.md +132 -0
- data/Examples.md +15 -0
- data/LICENSE +674 -0
- data/README.md +103 -0
- data/Rakefile +18 -0
- data/Technical Documentation.md +14 -0
- data/bin/create_installation_package.sh +49 -0
- data/bin/install.sh +45 -0
- data/bin/sapor.rb +24 -0
- data/bin/sapor.sh +106 -0
- data/data/hu/hungary-2014.txt +1680 -0
- data/data/hu/hungary_2014_screen_scraper.rb +48 -0
- data/data/hu/hungary_2014_to_psv.rb +80 -0
- data/data/hu/index-2014.txt +106 -0
- data/data/pl/2015-gl-lis-okr.csv +42 -0
- data/data/pl/poland_2015_to_psv.rb +79 -0
- data/data/pl/poland_2015_to_psv_with_ko_and_rsw.rb +94 -0
- data/data/pl/poland_2015_to_psv_with_ko_konf_kp_l_and_zp.rb +100 -0
- data/data/pl/poland_2015_to_psv_with_ko_sld_and_wi.rb +92 -0
- data/data/pl/poland_2015_to_psv_with_sld.rb +84 -0
- data/data/pl/poland_2015_to_psv_with_sld_and_wi.rb +85 -0
- data/data/uk/inject_ukip_2015_as_brexit_2019_in_2017.rb +54 -0
- data/data/uk/united_kingdom_2015.txt +651 -0
- data/data/uk/united_kingdom_2015_to_psv.rb +104 -0
- data/data/uk/united_kingdom_2017.txt +651 -0
- data/data/uk/united_kingdom_2017_to_psv.rb +104 -0
- data/data/uk/united_kingdom_2017_to_psv_with_brexit_and_chuk.rb +113 -0
- data/data/uk/united_kingdom_2017_to_psv_with_tig.rb +111 -0
- data/lib/sapor.rb +150 -0
- data/lib/sapor/binomials_cache.rb +45 -0
- data/lib/sapor/combinations_distribution.rb +222 -0
- data/lib/sapor/denominators.rb +67 -0
- data/lib/sapor/dichotomies.rb +138 -0
- data/lib/sapor/dichotomy.rb +164 -0
- data/lib/sapor/first_past_the_post.rb +82 -0
- data/lib/sapor/largest_remainder.rb +118 -0
- data/lib/sapor/log4r_logger.rb +49 -0
- data/lib/sapor/log_facade.rb +40 -0
- data/lib/sapor/multi_district_leveled_proportional.rb +64 -0
- data/lib/sapor/multi_district_proportional.rb +123 -0
- data/lib/sapor/multi_district_variable_threshold_proportional.rb +128 -0
- data/lib/sapor/number_formatter.rb +45 -0
- data/lib/sapor/options.rb +73 -0
- data/lib/sapor/poll.rb +286 -0
- data/lib/sapor/polychotomy.rb +200 -0
- data/lib/sapor/pseudorandom_multirange_enumerator.rb +87 -0
- data/lib/sapor/referendum_polychotomy.rb +165 -0
- data/lib/sapor/regional_data/area.rb +82 -0
- data/lib/sapor/regional_data/austria.rb +84 -0
- data/lib/sapor/regional_data/belgium-brussels-2014.psv +46 -0
- data/lib/sapor/regional_data/belgium-brussels-20190526.psv +33 -0
- data/lib/sapor/regional_data/belgium-flanders-2014.psv +80 -0
- data/lib/sapor/regional_data/belgium-flanders-20190526.psv +74 -0
- data/lib/sapor/regional_data/belgium-wallonia-2014.psv +114 -0
- data/lib/sapor/regional_data/belgium-wallonia-20190526.psv +93 -0
- data/lib/sapor/regional_data/belgium.rb +97 -0
- data/lib/sapor/regional_data/belgium_brussels.rb +62 -0
- data/lib/sapor/regional_data/belgium_flanders.rb +64 -0
- data/lib/sapor/regional_data/belgium_wallonia.rb +63 -0
- data/lib/sapor/regional_data/catalonia-2012-2015.psv +100 -0
- data/lib/sapor/regional_data/catalonia-2012.psv +87 -0
- data/lib/sapor/regional_data/catalonia-2015-jxcat.psv +68 -0
- data/lib/sapor/regional_data/catalonia-2015-no-jxsi.psv +68 -0
- data/lib/sapor/regional_data/catalonia-2015.psv +63 -0
- data/lib/sapor/regional_data/catalonia-jxcat.rb +109 -0
- data/lib/sapor/regional_data/catalonia-no-jxsi.rb +96 -0
- data/lib/sapor/regional_data/catalonia.rb +96 -0
- data/lib/sapor/regional_data/denmark-20150618-with-e-and-p.psv +164 -0
- data/lib/sapor/regional_data/denmark-20150618-with-e.psv +153 -0
- data/lib/sapor/regional_data/denmark-20150618-with-p.psv +153 -0
- data/lib/sapor/regional_data/denmark-20150618.psv +142 -0
- data/lib/sapor/regional_data/denmark.rb +128 -0
- data/lib/sapor/regional_data/denmark_with_e.rb +128 -0
- data/lib/sapor/regional_data/denmark_with_e_and_p.rb +128 -0
- data/lib/sapor/regional_data/denmark_with_p.rb +128 -0
- data/lib/sapor/regional_data/estonia.rb +88 -0
- data/lib/sapor/regional_data/european-union-great-britain-20140522-brexit-chuk.psv +172 -0
- data/lib/sapor/regional_data/european-union-great-britain-20140522.psv +146 -0
- data/lib/sapor/regional_data/european-union-great-britain-20190523.psv +141 -0
- data/lib/sapor/regional_data/european-union-ireland-2014-ia-ri-sd.psv +64 -0
- data/lib/sapor/regional_data/european-union-ireland-2014-ia-sd.psv +60 -0
- data/lib/sapor/regional_data/european-union-ireland-2014-ia.psv +56 -0
- data/lib/sapor/regional_data/european-union-ireland-2014-sd.psv +56 -0
- data/lib/sapor/regional_data/european-union-ireland-2014.psv +50 -0
- data/lib/sapor/regional_data/european-union-ireland-20190524-ia.psv +58 -0
- data/lib/sapor/regional_data/european-union-ireland-20190524.psv +52 -0
- data/lib/sapor/regional_data/european_union_27_austria.rb +76 -0
- data/lib/sapor/regional_data/european_union_27_croatia.rb +81 -0
- data/lib/sapor/regional_data/european_union_27_denmark.rb +77 -0
- data/lib/sapor/regional_data/european_union_27_estonia.rb +74 -0
- data/lib/sapor/regional_data/european_union_27_finland.rb +74 -0
- data/lib/sapor/regional_data/european_union_27_ireland.rb +96 -0
- data/lib/sapor/regional_data/european_union_27_ireland_with_ia.rb +97 -0
- data/lib/sapor/regional_data/european_union_27_italy.rb +84 -0
- data/lib/sapor/regional_data/european_union_27_netherlands.rb +81 -0
- data/lib/sapor/regional_data/european_union_27_poland.rb +84 -0
- data/lib/sapor/regional_data/european_union_27_romania.rb +78 -0
- data/lib/sapor/regional_data/european_union_27_slovakia.rb +80 -0
- data/lib/sapor/regional_data/european_union_27_spain.rb +82 -0
- data/lib/sapor/regional_data/european_union_27_sweden.rb +76 -0
- data/lib/sapor/regional_data/european_union_austria.rb +76 -0
- data/lib/sapor/regional_data/european_union_bulgaria.rb +81 -0
- data/lib/sapor/regional_data/european_union_croatia.rb +81 -0
- data/lib/sapor/regional_data/european_union_cyprus.rb +72 -0
- data/lib/sapor/regional_data/european_union_czech_republic.rb +82 -0
- data/lib/sapor/regional_data/european_union_denmark.rb +77 -0
- data/lib/sapor/regional_data/european_union_estonia.rb +74 -0
- data/lib/sapor/regional_data/european_union_finland.rb +74 -0
- data/lib/sapor/regional_data/european_union_flanders.rb +74 -0
- data/lib/sapor/regional_data/european_union_france.rb +84 -0
- data/lib/sapor/regional_data/european_union_france_2019.rb +84 -0
- data/lib/sapor/regional_data/european_union_french_community_of_belgium.rb +73 -0
- data/lib/sapor/regional_data/european_union_germany.rb +86 -0
- data/lib/sapor/regional_data/european_union_great_britain.rb +98 -0
- data/lib/sapor/regional_data/european_union_greece.rb +77 -0
- data/lib/sapor/regional_data/european_union_hungary.rb +76 -0
- data/lib/sapor/regional_data/european_union_ireland.rb +96 -0
- data/lib/sapor/regional_data/european_union_ireland_with_ia.rb +97 -0
- data/lib/sapor/regional_data/european_union_italy.rb +84 -0
- data/lib/sapor/regional_data/european_union_latvia.rb +81 -0
- data/lib/sapor/regional_data/european_union_lithuania.rb +80 -0
- data/lib/sapor/regional_data/european_union_luxembourg.rb +75 -0
- data/lib/sapor/regional_data/european_union_malta.rb +71 -0
- data/lib/sapor/regional_data/european_union_netherlands.rb +81 -0
- data/lib/sapor/regional_data/european_union_northern_ireland.rb +75 -0
- data/lib/sapor/regional_data/european_union_poland.rb +84 -0
- data/lib/sapor/regional_data/european_union_portugal.rb +75 -0
- data/lib/sapor/regional_data/european_union_romania.rb +78 -0
- data/lib/sapor/regional_data/european_union_slovakia.rb +81 -0
- data/lib/sapor/regional_data/european_union_slovenia.rb +85 -0
- data/lib/sapor/regional_data/european_union_spain.rb +82 -0
- data/lib/sapor/regional_data/european_union_sweden.rb +76 -0
- data/lib/sapor/regional_data/finland-20150419-with-sin.psv +224 -0
- data/lib/sapor/regional_data/finland-20150419.psv +212 -0
- data/lib/sapor/regional_data/finland.rb +107 -0
- data/lib/sapor/regional_data/finland_with_sin.rb +107 -0
- data/lib/sapor/regional_data/flanders-2014.psv +96 -0
- data/lib/sapor/regional_data/flanders-20190526.psv +87 -0
- data/lib/sapor/regional_data/flanders.rb +115 -0
- data/lib/sapor/regional_data/france.rb +38 -0
- data/lib/sapor/regional_data/greece.rb +92 -0
- data/lib/sapor/regional_data/hungary-2014.psv +2104 -0
- data/lib/sapor/regional_data/hungary.rb +116 -0
- data/lib/sapor/regional_data/iceland-20161029-midflokkurinn.psv +94 -0
- data/lib/sapor/regional_data/iceland-20161029.psv +88 -0
- data/lib/sapor/regional_data/iceland-20171028.psv +85 -0
- data/lib/sapor/regional_data/iceland.rb +133 -0
- data/lib/sapor/regional_data/latvia-20141004-kpv-p-par.psv +109 -0
- data/lib/sapor/regional_data/latvia-20141004-kpv-par.psv +103 -0
- data/lib/sapor/regional_data/latvia-20141004-kpv.psv +97 -0
- data/lib/sapor/regional_data/latvia-20141004.psv +89 -0
- data/lib/sapor/regional_data/latvia.rb +112 -0
- data/lib/sapor/regional_data/latvia_kpv.rb +112 -0
- data/lib/sapor/regional_data/latvia_kpv_p_par.rb +112 -0
- data/lib/sapor/regional_data/latvia_kpv_par.rb +112 -0
- data/lib/sapor/regional_data/luxembourg-20131020.psv +76 -0
- data/lib/sapor/regional_data/luxembourg.rb +82 -0
- data/lib/sapor/regional_data/netherlands.rb +108 -0
- data/lib/sapor/regional_data/norway.rb +425 -0
- data/lib/sapor/regional_data/norwegian_municipality.rb +68 -0
- data/lib/sapor/regional_data/poland-20151025-with-ko-and-l-without-n-po-r-and-zl.psv +321 -0
- data/lib/sapor/regional_data/poland-20151025-with-ko-konf-kp-l-and-zp-without-k-k15-n-pis-po-psl-r-and-zl.psv +280 -0
- data/lib/sapor/regional_data/poland-20151025-with-ko-sld-and-wi-without-n-po-and-zl.psv +403 -0
- data/lib/sapor/regional_data/poland-20151025-with-sld-and-wi-without-zl.psv +444 -0
- data/lib/sapor/regional_data/poland-20151025-with-sld-without-zl.psv +403 -0
- data/lib/sapor/regional_data/poland-20151025.psv +403 -0
- data/lib/sapor/regional_data/poland.rb +125 -0
- data/lib/sapor/regional_data/poland_with_ko_and_l_without_n_po_r_and_zl.rb +122 -0
- data/lib/sapor/regional_data/poland_with_ko_konf_kp_l_and_zp_without_k_k15_n_pis_po_psl_r_and_zl.rb +123 -0
- data/lib/sapor/regional_data/poland_with_ko_sld_and_wi_without_n_po_and_zl.rb +125 -0
- data/lib/sapor/regional_data/poland_with_sld_and_wi_without_zl.rb +126 -0
- data/lib/sapor/regional_data/poland_with_sld_without_zl.rb +126 -0
- data/lib/sapor/regional_data/portugal-20151004-with-a-and-ch-without-paf.psv +438 -0
- data/lib/sapor/regional_data/portugal-20151004-with-a-and-il-without-paf.psv +438 -0
- data/lib/sapor/regional_data/portugal-20151004-with-a-ch-and-il-without-paf.psv +461 -0
- data/lib/sapor/regional_data/portugal-20151004-with-a-without-paf.psv +415 -0
- data/lib/sapor/regional_data/portugal-20151004-with-ch-and-il-without-paf.psv +438 -0
- data/lib/sapor/regional_data/portugal-20151004-without-paf.psv +392 -0
- data/lib/sapor/regional_data/portugal-20151004.psv +370 -0
- data/lib/sapor/regional_data/portugal.rb +101 -0
- data/lib/sapor/regional_data/portugal_with_a_and_ch_without_paf.rb +92 -0
- data/lib/sapor/regional_data/portugal_with_a_and_il_without_paf.rb +92 -0
- data/lib/sapor/regional_data/portugal_with_a_ch_and_il_without_paf.rb +92 -0
- data/lib/sapor/regional_data/portugal_with_a_without_paf.rb +92 -0
- data/lib/sapor/regional_data/portugal_with_ch_and_il_without_paf.rb +92 -0
- data/lib/sapor/regional_data/portugal_without_paf.rb +92 -0
- data/lib/sapor/regional_data/slovakia.rb +81 -0
- data/lib/sapor/regional_data/slovenia.rb +114 -0
- data/lib/sapor/regional_data/spain-20160626.psv +619 -0
- data/lib/sapor/regional_data/spain.rb +136 -0
- data/lib/sapor/regional_data/sweden.rb +92 -0
- data/lib/sapor/regional_data/sweden_20140914.rb +89 -0
- data/lib/sapor/regional_data/united_kingdom-2015.psv +4358 -0
- data/lib/sapor/regional_data/united_kingdom-20170608-brexit-chuk.psv +5154 -0
- data/lib/sapor/regional_data/united_kingdom-20170608-brexit.psv +4521 -0
- data/lib/sapor/regional_data/united_kingdom-20170608-tig.psv +4529 -0
- data/lib/sapor/regional_data/united_kingdom-20170608.psv +3894 -0
- data/lib/sapor/regional_data/united_kingdom.rb +94 -0
- data/lib/sapor/regional_data/united_kingdom_with_brexit.rb +110 -0
- data/lib/sapor/regional_data/united_kingdom_with_brexit_and_chuk.rb +111 -0
- data/lib/sapor/regional_data/united_kingdom_with_tig.rb +111 -0
- data/lib/sapor/regional_data/utopia.rb +66 -0
- data/lib/sapor/regional_data/wallonia-2014.psv +101 -0
- data/lib/sapor/regional_data/wallonia-20190526.psv +88 -0
- data/lib/sapor/regional_data/wallonia.rb +112 -0
- data/lib/sapor/representatives_polychotomy.rb +338 -0
- data/lib/sapor/single_district_proportional.rb +75 -0
- data/sapor.gemspec +35 -0
- data/spec/integration/area_spec.rb +28 -0
- data/spec/integration/poll_spec.rb +112 -0
- data/spec/integration/sample.poll +8 -0
- data/spec/spec_helper.rb +31 -0
- data/spec/unit/area_spec.rb +115 -0
- data/spec/unit/austria_spec.rb +76 -0
- data/spec/unit/belgium_brussels_spec.rb +58 -0
- data/spec/unit/belgium_flanders_spec.rb +62 -0
- data/spec/unit/belgium_spec.rb +26 -0
- data/spec/unit/belgium_wallonia_spec.rb +65 -0
- data/spec/unit/binomials_cache_spec.rb +34 -0
- data/spec/unit/catalonia_spec.rb +74 -0
- data/spec/unit/combinations_distribution_spec.rb +241 -0
- data/spec/unit/denmark_spec.rb +56 -0
- data/spec/unit/denmark_with_e_and_p_spec.rb +58 -0
- data/spec/unit/denmark_with_e_spec.rb +57 -0
- data/spec/unit/denmark_with_p_spec.rb +57 -0
- data/spec/unit/denominators_spec.rb +40 -0
- data/spec/unit/dichotomies_spec.rb +154 -0
- data/spec/unit/dichotomy_spec.rb +320 -0
- data/spec/unit/estonia_spec.rb +65 -0
- data/spec/unit/european_union_27_austria_spec.rb +61 -0
- data/spec/unit/european_union_27_croatia_spec.rb +60 -0
- data/spec/unit/european_union_27_denmark_spec.rb +62 -0
- data/spec/unit/european_union_27_estonia_spec.rb +94 -0
- data/spec/unit/european_union_27_finland_spec.rb +75 -0
- data/spec/unit/european_union_27_ireland_spec.rb +72 -0
- data/spec/unit/european_union_27_ireland_with_ia_spec.rb +74 -0
- data/spec/unit/european_union_27_italy_spec.rb +69 -0
- data/spec/unit/european_union_27_netherlands_spec.rb +81 -0
- data/spec/unit/european_union_27_poland_spec.rb +69 -0
- data/spec/unit/european_union_27_romania_spec.rb +67 -0
- data/spec/unit/european_union_27_slovakia_spec.rb +111 -0
- data/spec/unit/european_union_27_spain_spec.rb +130 -0
- data/spec/unit/european_union_27_sweden_spec.rb +89 -0
- data/spec/unit/european_union_austria_spec.rb +61 -0
- data/spec/unit/european_union_bulgaria_spec.rb +97 -0
- data/spec/unit/european_union_croatia_spec.rb +59 -0
- data/spec/unit/european_union_cyprus_spec.rb +65 -0
- data/spec/unit/european_union_czech_republic_spec.rb +125 -0
- data/spec/unit/european_union_denmark_spec.rb +61 -0
- data/spec/unit/european_union_estonia_spec.rb +93 -0
- data/spec/unit/european_union_finland_spec.rb +75 -0
- data/spec/unit/european_union_flanders_spec.rb +56 -0
- data/spec/unit/european_union_france_2019_spec.rb +73 -0
- data/spec/unit/european_union_france_spec.rb +73 -0
- data/spec/unit/european_union_french_community_of_belgium_spec.rb +61 -0
- data/spec/unit/european_union_germany_spec.rb +90 -0
- data/spec/unit/european_union_great_britain_spec.rb +87 -0
- data/spec/unit/european_union_greece_spec.rb +148 -0
- data/spec/unit/european_union_hungary_spec.rb +57 -0
- data/spec/unit/european_union_ireland_spec.rb +72 -0
- data/spec/unit/european_union_ireland_with_ia_spec.rb +74 -0
- data/spec/unit/european_union_italy_spec.rb +69 -0
- data/spec/unit/european_union_latvia_spec.rb +76 -0
- data/spec/unit/european_union_lithuania_spec.rb +68 -0
- data/spec/unit/european_union_luxembourg_spec.rb +63 -0
- data/spec/unit/european_union_malta_spec.rb +60 -0
- data/spec/unit/european_union_netherlands_spec.rb +81 -0
- data/spec/unit/european_union_northern_ireland_spec.rb +66 -0
- data/spec/unit/european_union_poland_spec.rb +69 -0
- data/spec/unit/european_union_portugal_spec.rb +77 -0
- data/spec/unit/european_union_romania_spec.rb +67 -0
- data/spec/unit/european_union_slovakia_spec.rb +111 -0
- data/spec/unit/european_union_slovenia_spec.rb +77 -0
- data/spec/unit/european_union_spain_spec.rb +129 -0
- data/spec/unit/european_union_sweden_spec.rb +89 -0
- data/spec/unit/finland_spec.rb +65 -0
- data/spec/unit/finland_with_sin_spec.rb +67 -0
- data/spec/unit/first_past_the_post_spec.rb +54 -0
- data/spec/unit/flanders_spec.rb +70 -0
- data/spec/unit/france_spec.rb +32 -0
- data/spec/unit/greece_spec.rb +118 -0
- data/spec/unit/hungary_spec.rb +132 -0
- data/spec/unit/iceland_spec.rb +57 -0
- data/spec/unit/largest_remainder_spec.rb +79 -0
- data/spec/unit/latvia_kpv_p_par_spec.rb +38 -0
- data/spec/unit/latvia_kpv_par_spec.rb +38 -0
- data/spec/unit/latvia_kpv_spec.rb +38 -0
- data/spec/unit/latvia_spec.rb +60 -0
- data/spec/unit/luxembourg_spec.rb +54 -0
- data/spec/unit/multi_district_leveled_proportional_spec.rb +49 -0
- data/spec/unit/multi_district_proportional_spec.rb +81 -0
- data/spec/unit/netherlands_spec.rb +107 -0
- data/spec/unit/norway_spec.rb +64 -0
- data/spec/unit/norwegian_municipality_spec.rb +89 -0
- data/spec/unit/number_formatter_spec.rb +173 -0
- data/spec/unit/poland_spec.rb +62 -0
- data/spec/unit/poland_with_ko_and_l_without_n_po_r_and_zl_spec.rb +60 -0
- data/spec/unit/poland_with_ko_konf_kp_l_and_zp_without_k_k15_n_pis_po_psl_r_and_zl_spec.rb +59 -0
- data/spec/unit/poland_with_ko_sld_and_wi_without_n_po_and_zl_spec.rb +62 -0
- data/spec/unit/poland_with_sld_and_wi_without_zl_spec.rb +63 -0
- data/spec/unit/poland_with_sld_without_zl_spec.rb +62 -0
- data/spec/unit/poll_spec.rb +110 -0
- data/spec/unit/portugal_spec.rb +66 -0
- data/spec/unit/portugal_with_a_and_ch_without_paf_spec.rb +68 -0
- data/spec/unit/portugal_with_a_and_il_without_paf_spec.rb +68 -0
- data/spec/unit/portugal_with_a_ch_and_il_without_paf_spec.rb +69 -0
- data/spec/unit/portugal_with_a_without_paf_spec.rb +67 -0
- data/spec/unit/portugal_with_ch_and_il_without_paf_spec.rb +68 -0
- data/spec/unit/portugal_without_paf_spec.rb +66 -0
- data/spec/unit/pseudorandom_multirange_enumerator_spec.rb +82 -0
- data/spec/unit/referendum_polychotomy_spec.rb +289 -0
- data/spec/unit/representatives_polychotomy_spec.rb +332 -0
- data/spec/unit/slovakia_spec.rb +99 -0
- data/spec/unit/slovenia_spec.rb +80 -0
- data/spec/unit/spain_spec.rb +101 -0
- data/spec/unit/sweden_20140914_spec.rb +112 -0
- data/spec/unit/sweden_spec.rb +113 -0
- data/spec/unit/united_kingdom_spec.rb +65 -0
- data/spec/unit/united_kingdom_with_brexit_and_chuk_spec.rb +67 -0
- data/spec/unit/united_kingdom_with_brexit_spec.rb +66 -0
- data/spec/unit/united_kingdom_with_tig_spec.rb +66 -0
- data/spec/unit/wallonia_spec.rb +70 -0
- metadata +490 -0
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
# encoding: utf-8
|
|
2
|
+
#
|
|
3
|
+
# Statistical Analysis of Polling Results (SAPoR)
|
|
4
|
+
# Copyright (C) 2016 Filip van Laenen <f.a.vanlaenen@ieee.org>
|
|
5
|
+
#
|
|
6
|
+
# This file is part of SAPoR.
|
|
7
|
+
#
|
|
8
|
+
# SAPoR is free software: you can redistribute it and/or modify it under the
|
|
9
|
+
# terms of the GNU General Public License as published by the Free Software
|
|
10
|
+
# Foundation, either version 3 of the License, or (at your option) any later
|
|
11
|
+
# version.
|
|
12
|
+
#
|
|
13
|
+
# SAPoR is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
14
|
+
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
|
15
|
+
# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
16
|
+
#
|
|
17
|
+
# You can find a copy of the GNU General Public License in /doc/gpl.txt
|
|
18
|
+
#
|
|
19
|
+
|
|
20
|
+
require 'spec_helper'
|
|
21
|
+
|
|
22
|
+
describe Sapor::EuropeanUnionSlovenia, '#area_code' do
|
|
23
|
+
it 'returns EU[SI] as the area code' do
|
|
24
|
+
expect(Sapor::EuropeanUnionSlovenia.instance.area_code).to eq('EU[SI]')
|
|
25
|
+
end
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
describe Sapor::EuropeanUnionSlovenia, '#no_of_seats' do
|
|
29
|
+
it 'returns 8 as the number of seats' do
|
|
30
|
+
expect(Sapor::EuropeanUnionSlovenia.instance.no_of_seats).to eq(8)
|
|
31
|
+
end
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
describe Sapor::EuropeanUnionSlovenia, '#population_size' do
|
|
35
|
+
it 'returns a population size of 471,525' do
|
|
36
|
+
expect(Sapor::EuropeanUnionSlovenia.instance.population_size).to \
|
|
37
|
+
eq(471_525)
|
|
38
|
+
end
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
describe Sapor::EuropeanUnionSlovenia, '#seats' do
|
|
42
|
+
it 'calculates the number of seats for the election of 2014' do
|
|
43
|
+
results = { 'Kacin Konkretno (*)' => 19_659,
|
|
44
|
+
'Državljanska lista (ALDE)' => 4_570,
|
|
45
|
+
'Združena levica (GUE/NGL)' => 21_898,
|
|
46
|
+
'Slovenska nacionalna stranka (*)' => 16_166,
|
|
47
|
+
'Verjamem (Greens/EFA)' => 41_458,
|
|
48
|
+
'Nova Slovenija in Slovenska ljudska stranka (EPP)' => 66_114,
|
|
49
|
+
'Socialni demokrati (S&D)' => 32_330,
|
|
50
|
+
'Slovenska demokratska stranka (EPP)' => 99_206,
|
|
51
|
+
'Slovenski narod (*)' => 1_424,
|
|
52
|
+
'Piratska stranka Slovenije (Greens/EFA)' => 10_242,
|
|
53
|
+
'Solidarnost (*)' => 6_673,
|
|
54
|
+
'Zeleni Slovenije (*)' => 3_273,
|
|
55
|
+
'Demokratična stranka upokojencev Slovenije (ALDE)' => 32_604,
|
|
56
|
+
'Sanjska služba (*)' => 14_212,
|
|
57
|
+
'Pozitivna Slovenija (*)' => 26_510,
|
|
58
|
+
'Zares (*)' => 3_794 }
|
|
59
|
+
seats = Sapor::EuropeanUnionSlovenia.instance.seats(results)
|
|
60
|
+
expect(seats['Kacin Konkretno (*)']).to eq(0)
|
|
61
|
+
expect(seats['Državljanska lista (ALDE)']).to eq(0)
|
|
62
|
+
expect(seats['Združena levica (GUE/NGL)']).to eq(0)
|
|
63
|
+
expect(seats['Slovenska nacionalna stranka (*)']).to eq(0)
|
|
64
|
+
expect(seats['Verjamem (Greens/EFA)']).to eq(1)
|
|
65
|
+
expect(seats['Nova Slovenija in Slovenska ljudska stranka (EPP)']).to eq(2)
|
|
66
|
+
expect(seats['Socialni demokrati (S&D)']).to eq(1)
|
|
67
|
+
expect(seats['Slovenska demokratska stranka (EPP)']).to eq(3)
|
|
68
|
+
expect(seats['Slovenski narod (*)']).to eq(0)
|
|
69
|
+
expect(seats['Piratska stranka Slovenije (Greens/EFA)']).to eq(0)
|
|
70
|
+
expect(seats['Solidarnost (*)']).to eq(0)
|
|
71
|
+
expect(seats['Zeleni Slovenije (*)']).to eq(0)
|
|
72
|
+
expect(seats['Demokratična stranka upokojencev Slovenije (ALDE)']).to eq(1)
|
|
73
|
+
expect(seats['Sanjska služba (*)']).to eq(0)
|
|
74
|
+
expect(seats['Pozitivna Slovenija (*)']).to eq(0)
|
|
75
|
+
expect(seats['Zares (*)']).to eq(0)
|
|
76
|
+
end
|
|
77
|
+
end
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
# encoding: utf-8
|
|
2
|
+
#
|
|
3
|
+
# Statistical Analysis of Polling Results (SAPoR)
|
|
4
|
+
# Copyright (C) 2016 Filip van Laenen <f.a.vanlaenen@ieee.org>
|
|
5
|
+
#
|
|
6
|
+
# This file is part of SAPoR.
|
|
7
|
+
#
|
|
8
|
+
# SAPoR is free software: you can redistribute it and/or modify it under the
|
|
9
|
+
# terms of the GNU General Public License as published by the Free Software
|
|
10
|
+
# Foundation, either version 3 of the License, or (at your option) any later
|
|
11
|
+
# version.
|
|
12
|
+
#
|
|
13
|
+
# SAPoR is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
14
|
+
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
|
15
|
+
# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
16
|
+
#
|
|
17
|
+
# You can find a copy of the GNU General Public License in /doc/gpl.txt
|
|
18
|
+
#
|
|
19
|
+
|
|
20
|
+
require 'spec_helper'
|
|
21
|
+
|
|
22
|
+
describe Sapor::EuropeanUnionSpain, '#area_code' do
|
|
23
|
+
it 'returns EU[ES] as the area code' do
|
|
24
|
+
expect(Sapor::EuropeanUnionSpain.instance.area_code).to eq('EU[ES]')
|
|
25
|
+
end
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
describe Sapor::EuropeanUnionSpain, '#no_of_seats' do
|
|
29
|
+
it 'returns 54 as the number of seats' do
|
|
30
|
+
expect(Sapor::EuropeanUnionSpain.instance.no_of_seats).to eq(54)
|
|
31
|
+
end
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
describe Sapor::EuropeanUnionSpain, '#population_size' do
|
|
35
|
+
it 'returns a population size of 22,410,049' do
|
|
36
|
+
expect(Sapor::EuropeanUnionSpain.instance.population_size).to \
|
|
37
|
+
eq(22_410_049)
|
|
38
|
+
end
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
describe Sapor::EuropeanUnionSpain, '#seats' do
|
|
42
|
+
it 'calculates the number of seats using the votes of the 2014 election' do
|
|
43
|
+
results = { 'Partido Popular (EPP)' => 4_098_339,
|
|
44
|
+
'Partido Socialista Obrero Español (S&D)' => 3_614_232,
|
|
45
|
+
'La Izquierda Plural (GUE/NGL)' => 1_575_308,
|
|
46
|
+
'Podemos (GUE/NGL)' => 1_253_837,
|
|
47
|
+
'Unión Progreso y Democracia (ALDE)' => 1_022_232,
|
|
48
|
+
'Coalición por Europa (ALDE)' => 851_971,
|
|
49
|
+
'L’Esquerra pel Dret a Decidir (Greens/EFA)' => 630_072,
|
|
50
|
+
'Ciudadanos–Partido de la Ciudadanía (ALDE)' => 497_146,
|
|
51
|
+
'Los Pueblos Deciden (GUE/NGL)' => 326_464,
|
|
52
|
+
'Primavera Europea (Greens/EFA)' => 302_266,
|
|
53
|
+
'Vox (ECR)' => 246_833,
|
|
54
|
+
'Partido Animalista Contra el Maltrato Animal (—)' => 177_499,
|
|
55
|
+
'Escaños en Blanco (—)' => 115_682,
|
|
56
|
+
'Movimiento de Renovación Democrática de la Ciudadanía (—)' => \
|
|
57
|
+
105_666,
|
|
58
|
+
'Partido X (—)' => 100_561,
|
|
59
|
+
'Partido Andalucista (Greens/EFA)' => 49_523,
|
|
60
|
+
'Confederación Pirata (—)' => 38_690,
|
|
61
|
+
'Foro de Ciudadanos (—)' => 32_962,
|
|
62
|
+
'Agrupación de Electores de Discapacitados y Enfermedades' \
|
|
63
|
+
' Raras (—)' => 32_833,
|
|
64
|
+
'Recortes Cero (—)' => 30_827,
|
|
65
|
+
'Partido Comunista de los Pueblos de España (—)' => 29_324,
|
|
66
|
+
'Iniciativa Feminista (—)' => 23_140,
|
|
67
|
+
'Falange Española de las JONS (—)' => 21_687,
|
|
68
|
+
'Ciudadanos Libres Unidos (—)' => 18_287,
|
|
69
|
+
'Impulso Social (—)' => 17_879,
|
|
70
|
+
'La España en Marcha (—)' => 17_035,
|
|
71
|
+
'Partido Humanista (—)' => 14_896,
|
|
72
|
+
'Democracia Nacional (—)' => 13_079,
|
|
73
|
+
'Proyecto Europa (—)' => 11_502,
|
|
74
|
+
'Partido da Terra (—)' => 9_940,
|
|
75
|
+
'Partido de la Libertad Individual (—)' => 9_670,
|
|
76
|
+
'Movimiento Social Republicano (—)' => 8_909,
|
|
77
|
+
'Extremadura Unida (—)' => 8_821,
|
|
78
|
+
'Alternativa Republicana (—)' => 8_593,
|
|
79
|
+
'Por la República, Por la Ruptura con la Unión Europea (—)' => \
|
|
80
|
+
8_309,
|
|
81
|
+
'Solidaridad y Autogestión Internacionalista (—)' => 6_929,
|
|
82
|
+
'Salamanca-Zamora-León (—)' => 6_759,
|
|
83
|
+
'Extremeños por Europa Coalición electoral (—)' => 5_967,
|
|
84
|
+
'Movimiento Corriente Roja (—)' => 4_980 }
|
|
85
|
+
seats = Sapor::EuropeanUnionSpain.instance.seats(results)
|
|
86
|
+
expect(seats['Partido Popular (EPP)']).to eq(16)
|
|
87
|
+
expect(seats['Partido Socialista Obrero Español (S&D)']).to eq(14)
|
|
88
|
+
expect(seats['La Izquierda Plural (GUE/NGL)']).to eq(6)
|
|
89
|
+
expect(seats['Podemos (GUE/NGL)']).to eq(5)
|
|
90
|
+
expect(seats['Unión Progreso y Democracia (ALDE)']).to eq(4)
|
|
91
|
+
expect(seats['Coalición por Europa (ALDE)']).to eq(3)
|
|
92
|
+
expect(seats['L’Esquerra pel Dret a Decidir (Greens/EFA)']).to eq(2)
|
|
93
|
+
expect(seats['Ciudadanos–Partido de la Ciudadanía (ALDE)']).to eq(2)
|
|
94
|
+
expect(seats['Los Pueblos Deciden (GUE/NGL)']).to eq(1)
|
|
95
|
+
expect(seats['Primavera Europea (Greens/EFA)']).to eq(1)
|
|
96
|
+
expect(seats['Vox (ECR)']).to eq(0)
|
|
97
|
+
expect(seats['Partido Animalista Contra el Maltrato Animal (—)']).to eq(0)
|
|
98
|
+
expect(seats['Escaños en Blanco (—)']).to eq(0)
|
|
99
|
+
expect(seats['Movimiento de Renovación Democrática de la Ciudadanía (—)']) \
|
|
100
|
+
.to eq(0)
|
|
101
|
+
expect(seats['Partido X (—)']).to eq(0)
|
|
102
|
+
expect(seats['Partido Andalucista (Greens/EFA)']).to eq(0)
|
|
103
|
+
expect(seats['Confederación Pirata (—)']).to eq(0)
|
|
104
|
+
expect(seats['Foro de Ciudadanos (—)']).to eq(0)
|
|
105
|
+
expect(seats['Agrupación de Electores de Discapacitados y Enfermedades' \
|
|
106
|
+
' Raras (—)']).to eq(0)
|
|
107
|
+
expect(seats['Recortes Cero (—)']).to eq(0)
|
|
108
|
+
expect(seats['Partido Comunista de los Pueblos de España (—)']).to eq(0)
|
|
109
|
+
expect(seats['Iniciativa Feminista (—)']).to eq(0)
|
|
110
|
+
expect(seats['Falange Española de las JONS (—)']).to eq(0)
|
|
111
|
+
expect(seats['Ciudadanos Libres Unidos (—)']).to eq(0)
|
|
112
|
+
expect(seats['Impulso Social (—)']).to eq(0)
|
|
113
|
+
expect(seats['La España en Marcha (—)']).to eq(0)
|
|
114
|
+
expect(seats['Partido Humanista (—)']).to eq(0)
|
|
115
|
+
expect(seats['Democracia Nacional (—)']).to eq(0)
|
|
116
|
+
expect(seats['Proyecto Europa (—)']).to eq(0)
|
|
117
|
+
expect(seats['Partido da Terra (—)']).to eq(0)
|
|
118
|
+
expect(seats['Partido de la Libertad Individual (—)']).to eq(0)
|
|
119
|
+
expect(seats['Movimiento Social Republicano (—)']).to eq(0)
|
|
120
|
+
expect(seats['Extremadura Unida (—)']).to eq(0)
|
|
121
|
+
expect(seats['Alternativa Republicana (—)']).to eq(0)
|
|
122
|
+
expect(seats['Por la República, Por la Ruptura con la Unión Europea (—)']) \
|
|
123
|
+
.to eq(0)
|
|
124
|
+
expect(seats['Solidaridad y Autogestión Internacionalista (—)']).to eq(0)
|
|
125
|
+
expect(seats['Salamanca-Zamora-León (—)']).to eq(0)
|
|
126
|
+
expect(seats['Extremeños por Europa Coalición electoral (—)']).to eq(0)
|
|
127
|
+
expect(seats['Movimiento Corriente Roja (—)']).to eq(0)
|
|
128
|
+
end
|
|
129
|
+
end
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
# encoding: utf-8
|
|
2
|
+
#
|
|
3
|
+
# Statistical Analysis of Polling Results (SAPoR)
|
|
4
|
+
# Copyright (C) 2016 Filip van Laenen <f.a.vanlaenen@ieee.org>
|
|
5
|
+
#
|
|
6
|
+
# This file is part of SAPoR.
|
|
7
|
+
#
|
|
8
|
+
# SAPoR is free software: you can redistribute it and/or modify it under the
|
|
9
|
+
# terms of the GNU General Public License as published by the Free Software
|
|
10
|
+
# Foundation, either version 3 of the License, or (at your option) any later
|
|
11
|
+
# version.
|
|
12
|
+
#
|
|
13
|
+
# SAPoR is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
14
|
+
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
|
15
|
+
# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
16
|
+
#
|
|
17
|
+
# You can find a copy of the GNU General Public License in /doc/gpl.txt
|
|
18
|
+
#
|
|
19
|
+
|
|
20
|
+
require 'spec_helper'
|
|
21
|
+
|
|
22
|
+
describe Sapor::EuropeanUnionSweden, '#area_code' do
|
|
23
|
+
it 'returns EU[SE] as the area code' do
|
|
24
|
+
expect(Sapor::EuropeanUnionSweden.instance.area_code).to eq('EU[SE]')
|
|
25
|
+
end
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
describe Sapor::EuropeanUnionSweden, '#no_of_seats' do
|
|
29
|
+
it 'returns 20 as the number of seats' do
|
|
30
|
+
expect(Sapor::EuropeanUnionSweden.instance.no_of_seats).to eq(20)
|
|
31
|
+
end
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
describe Sapor::EuropeanUnionSweden, '#population_size' do
|
|
35
|
+
it 'returns a population size of 4,151,470' do
|
|
36
|
+
expect(Sapor::EuropeanUnionSweden.instance.population_size).to \
|
|
37
|
+
eq(4_151_470)
|
|
38
|
+
end
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
describe Sapor::EuropeanUnionSweden, '#seats' do
|
|
42
|
+
it 'calculates the number of seats for the election of 2014' do
|
|
43
|
+
results = { 'Sveriges socialdemokratiska arbetareparti (S&D)' => 899_074,
|
|
44
|
+
'Miljöpartiet de gröna (Greens/EFA)' => 572_591,
|
|
45
|
+
'Moderata samlingspartiet (EPP)' => 507_488,
|
|
46
|
+
'Liberalerna (ALDE)' => 368_514,
|
|
47
|
+
'Sverigedemokraterna (EFDD)' => 359_248,
|
|
48
|
+
'Centerpartiet (ALDE)' => 241_101,
|
|
49
|
+
'Vänsterpartiet (GUE/NGL)' => 234_272,
|
|
50
|
+
'Kristdemokraterna (EPP)' => 220_574,
|
|
51
|
+
'Feministiskt initiativ (S&D)' => 204_005,
|
|
52
|
+
'Piratpartiet (Greens/EFA)' => 82_763,
|
|
53
|
+
'Junilistan (GUE/NGL)' => 11_629,
|
|
54
|
+
'Djurens parti (GUE/NGL)' => 8_773,
|
|
55
|
+
'Liberala partiet (—)' => 492,
|
|
56
|
+
'Europeiska arbetarpartiet (—)' => 170,
|
|
57
|
+
'Sverigesmultidemokrater (—)' => 133,
|
|
58
|
+
'Sverige ut ur EU–Frihetliga Rättvisepartiet (—)' => 106,
|
|
59
|
+
'Socialistiska välfärdspartiet (—)' => 86,
|
|
60
|
+
'Äkta demokrati (—)' => 72,
|
|
61
|
+
'Sveriges nationella demokratiska parti (—)' => 49,
|
|
62
|
+
'666 för en EU:s super-state med frihet, jämlikhet, rättvisa,' \
|
|
63
|
+
' fred, kärlek och lyckan (—)' => 11,
|
|
64
|
+
'Republicans right (—)' => 9 }
|
|
65
|
+
seats = Sapor::EuropeanUnionSweden.instance.seats(results)
|
|
66
|
+
expect(seats['Sveriges socialdemokratiska arbetareparti (S&D)']).to eq(5)
|
|
67
|
+
expect(seats['Miljöpartiet de gröna (Greens/EFA)']).to eq(4)
|
|
68
|
+
expect(seats['Moderata samlingspartiet (EPP)']).to eq(3)
|
|
69
|
+
expect(seats['Liberalerna (ALDE)']).to eq(2)
|
|
70
|
+
expect(seats['Sverigedemokraterna (EFDD)']).to eq(2)
|
|
71
|
+
expect(seats['Centerpartiet (ALDE)']).to eq(1)
|
|
72
|
+
expect(seats['Vänsterpartiet (GUE/NGL)']).to eq(1)
|
|
73
|
+
expect(seats['Kristdemokraterna (EPP)']).to eq(1)
|
|
74
|
+
expect(seats['Feministiskt initiativ (S&D)']).to eq(1)
|
|
75
|
+
expect(seats['Piratpartiet (Greens/EFA)']).to eq(0)
|
|
76
|
+
expect(seats['Junilistan (GUE/NGL)']).to eq(0)
|
|
77
|
+
expect(seats['Djurens parti (GUE/NGL)']).to eq(0)
|
|
78
|
+
expect(seats['Liberala partiet (—)']).to eq(0)
|
|
79
|
+
expect(seats['Europeiska arbetarpartiet (—)']).to eq(0)
|
|
80
|
+
expect(seats['Sverigesmultidemokrater (—)']).to eq(0)
|
|
81
|
+
expect(seats['Sverige ut ur EU–Frihetliga Rättvisepartiet (—)']).to eq(0)
|
|
82
|
+
expect(seats['Socialistiska välfärdspartiet (—)']).to eq(0)
|
|
83
|
+
expect(seats['Äkta demokrati (—)']).to eq(0)
|
|
84
|
+
expect(seats['Sveriges nationella demokratiska parti (—)']).to eq(0)
|
|
85
|
+
expect(seats['666 för en EU:s super-state med frihet, jämlikhet,' \
|
|
86
|
+
' rättvisa, fred, kärlek och lyckan (—)']).to eq(0)
|
|
87
|
+
expect(seats['Republicans right (—)']).to eq(0)
|
|
88
|
+
end
|
|
89
|
+
end
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
#
|
|
2
|
+
# Statistical Analysis of Polling Results (SAPoR)
|
|
3
|
+
# Copyright (C) 2016 Filip van Laenen <f.a.vanlaenen@ieee.org>
|
|
4
|
+
#
|
|
5
|
+
# This file is part of SAPoR.
|
|
6
|
+
#
|
|
7
|
+
# SAPoR is free software: you can redistribute it and/or modify it under the
|
|
8
|
+
# terms of the GNU General Public License as published by the Free Software
|
|
9
|
+
# Foundation, either version 3 of the License, or (at your option) any later
|
|
10
|
+
# version.
|
|
11
|
+
#
|
|
12
|
+
# SAPoR is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
13
|
+
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
|
14
|
+
# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
15
|
+
#
|
|
16
|
+
# You can find a copy of the GNU General Public License in /doc/gpl.txt
|
|
17
|
+
#
|
|
18
|
+
|
|
19
|
+
require 'spec_helper'
|
|
20
|
+
|
|
21
|
+
describe Sapor::Finland, '#area_code' do
|
|
22
|
+
it 'returns FI as the area code' do
|
|
23
|
+
expect(Sapor::Finland.instance.area_code).to eq('FI')
|
|
24
|
+
end
|
|
25
|
+
end
|
|
26
|
+
|
|
27
|
+
describe Sapor::Finland, '#no_of_seats' do
|
|
28
|
+
it 'returns 200 as the number of seats' do
|
|
29
|
+
expect(Sapor::Finland.instance.no_of_seats).to eq(200)
|
|
30
|
+
end
|
|
31
|
+
end
|
|
32
|
+
|
|
33
|
+
describe Sapor::Finland, '#population_size' do
|
|
34
|
+
it 'returns a population size of 2,968,459' do
|
|
35
|
+
expect(Sapor::Finland.instance.population_size).to eq(2_968_459)
|
|
36
|
+
end
|
|
37
|
+
end
|
|
38
|
+
|
|
39
|
+
describe Sapor::Finland, '#seats' do
|
|
40
|
+
it 'calculates the number of seats for the election of 2015 adjusted for' \
|
|
41
|
+
' the seat distribution for 2019' do
|
|
42
|
+
Finland = Sapor::Finland.instance
|
|
43
|
+
results = Finland.overall_election_results_of_2015
|
|
44
|
+
seats = Sapor::Finland.instance.seats(results)
|
|
45
|
+
expect(seats['Suomen Keskusta']).to eq(49 - 1)
|
|
46
|
+
expect(seats['Perussuomalaiset']).to eq(38)
|
|
47
|
+
expect(seats['Kansallinen Kokoomus']).to eq(37)
|
|
48
|
+
expect(seats['Suomen Sosialidemokraattinen Puolue']).to eq(34)
|
|
49
|
+
expect(seats['Vihreä liitto']).to eq(15 + 1)
|
|
50
|
+
expect(seats['Vasemmistoliitto']).to eq(12)
|
|
51
|
+
expect(seats['Svenska folkpartiet i Finland']).to eq(9)
|
|
52
|
+
expect(seats['Kristillisdemokraatit']).to eq(5)
|
|
53
|
+
expect(seats['Åländsk samling']).to eq(1)
|
|
54
|
+
expect(seats['Piraattipuolue']).to eq(0)
|
|
55
|
+
expect(seats['Itsenäisyyspuolue']).to eq(0)
|
|
56
|
+
expect(seats['Suomen Kommunistinen Puolue']).to eq(0)
|
|
57
|
+
expect(seats['Muutos 2011']).to eq(0)
|
|
58
|
+
expect(
|
|
59
|
+
seats['Kommunistinen Työväenpuolue–Rauhan ja Sosialismin puolesta']
|
|
60
|
+
).to eq(0)
|
|
61
|
+
expect(seats['Suomen Työväenpuolue']).to eq(0)
|
|
62
|
+
expect(seats['Köyhien Asialla']).to eq(0)
|
|
63
|
+
expect(seats['Liberalerna på Åland']).to eq(0)
|
|
64
|
+
end
|
|
65
|
+
end
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
#
|
|
2
|
+
# Statistical Analysis of Polling Results (SAPoR)
|
|
3
|
+
# Copyright (C) 2016 Filip van Laenen <f.a.vanlaenen@ieee.org>
|
|
4
|
+
#
|
|
5
|
+
# This file is part of SAPoR.
|
|
6
|
+
#
|
|
7
|
+
# SAPoR is free software: you can redistribute it and/or modify it under the
|
|
8
|
+
# terms of the GNU General Public License as published by the Free Software
|
|
9
|
+
# Foundation, either version 3 of the License, or (at your option) any later
|
|
10
|
+
# version.
|
|
11
|
+
#
|
|
12
|
+
# SAPoR is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
13
|
+
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
|
14
|
+
# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
15
|
+
#
|
|
16
|
+
# You can find a copy of the GNU General Public License in /doc/gpl.txt
|
|
17
|
+
#
|
|
18
|
+
|
|
19
|
+
require 'spec_helper'
|
|
20
|
+
|
|
21
|
+
describe Sapor::FinlandWithSin, '#area_code' do
|
|
22
|
+
it 'returns FI∪{SIN} as the area code' do
|
|
23
|
+
expect(Sapor::FinlandWithSin.instance.area_code).to eq('FI∪{SIN}')
|
|
24
|
+
end
|
|
25
|
+
end
|
|
26
|
+
|
|
27
|
+
describe Sapor::FinlandWithSin, '#no_of_seats' do
|
|
28
|
+
it 'returns 200 as the number of seats' do
|
|
29
|
+
expect(Sapor::FinlandWithSin.instance.no_of_seats).to eq(200)
|
|
30
|
+
end
|
|
31
|
+
end
|
|
32
|
+
|
|
33
|
+
describe Sapor::FinlandWithSin, '#population_size' do
|
|
34
|
+
it 'returns a population size of 2,968,459' do
|
|
35
|
+
expect(Sapor::FinlandWithSin.instance.population_size).to eq(2_968_459)
|
|
36
|
+
end
|
|
37
|
+
end
|
|
38
|
+
|
|
39
|
+
describe Sapor::FinlandWithSin, '#seats' do
|
|
40
|
+
it 'calculates the number of seats for the election of 2015 adjusted for' \
|
|
41
|
+
' the seat distribution for 2019 and with PS divided equally into PS' \
|
|
42
|
+
' and SIN' do
|
|
43
|
+
FinlandWithSin = Sapor::FinlandWithSin.instance
|
|
44
|
+
results = FinlandWithSin.overall_election_results_of_2015
|
|
45
|
+
seats = Sapor::FinlandWithSin.instance.seats(results)
|
|
46
|
+
expect(seats['Suomen Keskusta']).to eq(49 - 1 + 1)
|
|
47
|
+
expect(seats['Perussuomalaiset']).to eq(38 - 22)
|
|
48
|
+
expect(seats['Sininen tulevaisuus']).to eq(0 + 15)
|
|
49
|
+
expect(seats['Kansallinen Kokoomus']).to eq(37 + 3)
|
|
50
|
+
expect(seats['Suomen Sosialidemokraattinen Puolue']).to eq(34 + 2)
|
|
51
|
+
expect(seats['Vihreä liitto']).to eq(15 + 1)
|
|
52
|
+
expect(seats['Vasemmistoliitto']).to eq(12)
|
|
53
|
+
expect(seats['Svenska folkpartiet i Finland']).to eq(9 + 1)
|
|
54
|
+
expect(seats['Kristillisdemokraatit']).to eq(5)
|
|
55
|
+
expect(seats['Åländsk samling']).to eq(1)
|
|
56
|
+
expect(seats['Piraattipuolue']).to eq(0)
|
|
57
|
+
expect(seats['Itsenäisyyspuolue']).to eq(0)
|
|
58
|
+
expect(seats['Suomen Kommunistinen Puolue']).to eq(0)
|
|
59
|
+
expect(seats['Muutos 2011']).to eq(0)
|
|
60
|
+
expect(
|
|
61
|
+
seats['Kommunistinen Työväenpuolue–Rauhan ja Sosialismin puolesta']
|
|
62
|
+
).to eq(0)
|
|
63
|
+
expect(seats['Suomen Työväenpuolue']).to eq(0)
|
|
64
|
+
expect(seats['Köyhien Asialla']).to eq(0)
|
|
65
|
+
expect(seats['Liberalerna på Åland']).to eq(0)
|
|
66
|
+
end
|
|
67
|
+
end
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
# encoding: utf-8
|
|
2
|
+
#
|
|
3
|
+
# Statistical Analysis of Polling Results (SAPoR)
|
|
4
|
+
# Copyright (C) 2016 Filip van Laenen <f.a.vanlaenen@ieee.org>
|
|
5
|
+
#
|
|
6
|
+
# This file is part of SAPoR.
|
|
7
|
+
#
|
|
8
|
+
# SAPoR is free software: you can redistribute it and/or modify it under the
|
|
9
|
+
# terms of the GNU General Public License as published by the Free Software
|
|
10
|
+
# Foundation, either version 3 of the License, or (at your option) any later
|
|
11
|
+
# version.
|
|
12
|
+
#
|
|
13
|
+
# SAPoR is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
14
|
+
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
|
15
|
+
# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
16
|
+
#
|
|
17
|
+
# You can find a copy of the GNU General Public License in /doc/gpl.txt
|
|
18
|
+
#
|
|
19
|
+
|
|
20
|
+
require 'spec_helper'
|
|
21
|
+
|
|
22
|
+
SAMPLE_RG_ELECTION_RESULT = { 'Red' => 91_811, 'Green' => 190_934 }.freeze
|
|
23
|
+
|
|
24
|
+
SAMPLE_DETAILED_ELECTION_RESULT = { 'North' => { 'Red' => 50, 'Green' => 70 },
|
|
25
|
+
'South' => { 'Red' => 70, 'Green' => 50,
|
|
26
|
+
'Blue' => 100 } }.freeze
|
|
27
|
+
|
|
28
|
+
FPTP = Sapor::FirstPastThePost.new(SAMPLE_RG_ELECTION_RESULT,
|
|
29
|
+
SAMPLE_DETAILED_ELECTION_RESULT)
|
|
30
|
+
|
|
31
|
+
describe Sapor::FirstPastThePost, '#project' do
|
|
32
|
+
it 'projects same result as last result if fed with last election result' do
|
|
33
|
+
projection = FPTP.project(SAMPLE_RG_ELECTION_RESULT)
|
|
34
|
+
expect(projection['Red']).to eq(0)
|
|
35
|
+
expect(projection['Green']).to eq(1)
|
|
36
|
+
expect(projection['Other']).to eq(1)
|
|
37
|
+
end
|
|
38
|
+
|
|
39
|
+
it 'it moves a seat to Red if Red is polling well enough' do
|
|
40
|
+
projection = FPTP.project('Red' => 91_811 * 70 / 49,
|
|
41
|
+
'Green' => 190_934)
|
|
42
|
+
expect(projection['Red']).to eq(1)
|
|
43
|
+
expect(projection['Green']).to eq(0)
|
|
44
|
+
expect(projection['Other']).to eq(1)
|
|
45
|
+
end
|
|
46
|
+
|
|
47
|
+
it 'it moves a seat away from Other if Red is polling well enough' do
|
|
48
|
+
projection = FPTP.project('Red' => 91_811 * 101 / 70,
|
|
49
|
+
'Green' => 190_934 * 70 / 101)
|
|
50
|
+
expect(projection['Red']).to eq(2)
|
|
51
|
+
expect(projection['Green']).to eq(0)
|
|
52
|
+
expect(projection['Other']).to eq(0)
|
|
53
|
+
end
|
|
54
|
+
end
|