diff options
-rw-r--r-- | Makefile | 7 | ||||
-rw-r--r-- | example/HLC.simu.pheno.txt | 427 | ||||
-rw-r--r-- | src/gemma.cpp | 4 | ||||
-rw-r--r-- | src/io.cpp | 59 | ||||
-rw-r--r-- | src/lm.cpp | 12 | ||||
-rw-r--r-- | src/lmm.cpp | 213 | ||||
-rw-r--r-- | src/mvlmm.cpp | 5 | ||||
-rw-r--r-- | src/param.h | 5 | ||||
-rw-r--r-- | src/prdt.cpp | 2 | ||||
-rw-r--r-- | src/varcov.cpp | 2 | ||||
-rw-r--r-- | src/vc.cpp | 10 | ||||
-rwxr-xr-x | test/dev_test_suite.sh | 20 | ||||
-rwxr-xr-x | test/lengthy_test_suite.sh | 55 | ||||
-rwxr-xr-x | test/test_suite.sh | 20 |
14 files changed, 687 insertions, 154 deletions
diff --git a/Makefile b/Makefile index 81367d6..dafcb38 100644 --- a/Makefile +++ b/Makefile @@ -144,8 +144,15 @@ slow-check: all cd test && ./test_suite.sh | tee ../test.log grep -q 'success rate: 100%' test.log +lengthy-check: all + rm -vf test/output/* + cd test && ./lengthy_test_suite.sh | tee ../lengthy_test.log + grep -q 'success rate: 100%' lengthy_test.log + check: fast-check slow-check +check-all: check lengthy-check + clean: rm -vf $(SRC_DIR)/*.o rm -vf $(SRC_DIR)/*~ diff --git a/example/HLC.simu.pheno.txt b/example/HLC.simu.pheno.txt new file mode 100644 index 0000000..882524a --- /dev/null +++ b/example/HLC.simu.pheno.txt @@ -0,0 +1,427 @@ +4.30079 0.182 -0.190586 -0.530973 -0.241971 -0.037369 -0.193058 -0.246519 -0.297597 -0.422828 -0.683131 -0.365192.69925 -6.09842 -0.997342 3.1659 -4.85071 -7.89172 -4.08795 -4.71129 -0.899308 -8.98116 +30.3996 0.174 -0.756165 -0.0129065 0.698053 0.378273 -0.330144 0.1068 -0.352508 -0.216064 0.289174 0.886406 -3.62642 -6.96845 6.66188 -9.59616 -2.0551 1.0784 -7.9724 1.75301 -0.647582 -6.57505 +5.09158 -0.040 1.17441 0.0315938 0.622833 0.545887 0.333927 0.593245 2.00365 0.503034 0.509897 0.703673 6.35907 -2.76265 -5.65188 0.0153553 5.15565 1.56376 4.02524 2.13856 4.10387 1.77838 +9.46331 0.153 -0.502174 -0.852084 -0.614021 0.238633 0.080736 0.080477 -0.709692 0.0712945 -0.849603 -0.114495 0.322482 7.03946 3.18 10.4904 2.20482 5.88917 -1.33739 3.92062 3.56902 0.23268 +-18.8116 0.044 -0.644747 -1.16015 -0.163684 0.145542 -0.962994 -0.919736 -0.250149 -0.404924 0.088679 -0.326259 -6.29168 0.760237 -8.68053 -8.40828 1.58603 0.119698 -2.0643 -6.98713 6.35583 -3.73874 +-6.81242 -0.063 0.167867 -0.30288 0.542077 -0.0845357 0.638986 -0.165061 0.48343 0.313352 0.519978 0.290043 -0.0154612 10.0453 12.8477 4.90469 3.48486 4.36344 6.62452 3.94107 1.11946 -2.04682 +-20.0013 0.081 -0.735156 -0.731781 0.0483402 -0.38362 -0.815132 -0.679567 -0.692132 -0.583948 -1.27304 -0.3171918.28155 11.7718 13.1838 18.3047 7.31036 2.7019 9.21239 16.706 8.35408 14.9079 +-12.3511 -0.037 -0.330382 -0.554235 -0.764835 0.0475339 -0.449305 0.0915239 -0.0782816 -0.741444 -0.342957 -0.2935895.85753 -10.1469 -3.18652 -0.766356 -6.60917 -6.51276 -6.2179 4.44999 7.08322 -2.74688 +3.11482 -0.007 -0.342442 0.561473 -0.603826 0.0685578 -0.159308 -0.368915 -0.535968 -0.66079 -0.241745 -0.04594122.9882 -12.7214 -6.38287 5.74052 -6.37549 -1.89355 -7.67737 -5.84762 -3.67782 0.691157 +7.11157 0.092 -0.770454 -0.687425 -0.0942635 -0.559406 -0.556375 0.841368 -0.677135 0.0855887 -0.339851 0.0504351-4.03686 -2.39512 -7.13925 1.92984 -4.47788 -3.28657 -1.45937 -7.07676 -3.37021 1.95363 +-37.86 -0.005 1.77974 1.52886 2.12291 1.59104 1.44794 1.43852 1.00457 1.00951 1.31966 1.20888 4.26267 7.21746 5.02493 2.66466 1.58865 0.944323 -1.18915 -1.56361 7.0478 6.38826 +-0.98574 -0.070 -0.0183864 -0.465254 -0.322 0.130881 -0.361272 -0.198633 -0.0297887 -0.364153 -0.248175 0.299799 -6.17324 -3.84108 -1.63408 -3.23286 -2.55856 -3.17738 -4.32796 1.71749 -1.25208 -6.23819 +12.2701 -0.053 -0.269319 -0.488578 0.36435 -0.116801 0.01588 -0.107565 0.252097 -0.617587 -0.515279 -0.0786428 5.23767 2.80423 6.55145 -0.571431 3.99268 2.94141 6.71769 3.44793 2.00127 12.3797 +6.28342 0.103 0.225299 -0.133847 -0.469864 -0.625531 -0.544982 -1.02154 -0.694379 -0.0111734 -0.622413 0.17508 1.40659 -8.78164 -3.75035 -6.76237 -2.12977 -0.029599 0.440497 -5.20206 -3.41635 0.368391 +-4.48825 0.189 -0.614829 -0.221294 -0.874144 -0.291857 0.683764 -0.267327 0.02061 -0.790005 0.383739 -0.364921 -0.91569 -7.54058 -3.80568 -11.299 -5.94179 0.725267 -2.75382 -3.06261 -6.1451 -5.72544 +24.653 0.099 0.970842 1.09176 0.823816 0.722382 0.42305 1.02979 1.03299 0.832976 0.962136 0.452328 -7.56561 0.752318 -6.75209 -8.07279 -0.499436 1.0136 -3.63183 1.88776 0.514223 -11.7922 +-5.17434 0.142 -1.49269 -0.840727 -0.638092 -0.976349 -0.830499 -1.07572 -0.515428 -0.35846 -1.03027 0.0173654 2.41685 -1.46602 -9.66524 -6.93581 -2.80223 -0.466852 -8.27836 -5.88719 2.03021 -8.09412 +6.80427 -0.243 1.08699 -0.420887 -0.154189 -0.0499706 -0.0954385 -0.328928 -0.108158 0.625641 -0.300759 -0.24652-4.0422 5.7473 5.56476 0.358114 1.55691 3.53671 4.36929 -0.577303 2.99366 -4.6848 +-26.6919 -0.010 0.613079 -0.968246 -0.380294 -0.808311 0.162005 -0.0283518 -0.789044 -0.250561 -0.478466 -0.076133810.4975 3.51047 14.6681 2.62758 6.06159 15.678 7.48949 7.41393 14.0987 6.44829 +-2.31297 -0.021 -0.0181208 -0.113322 -1.14781 -0.605107 0.271612 -1.3041 -1.20608 -0.160102 -0.263737 -0.756681 -3.05274 -5.77926 -2.75155 -4.01462 -5.437 -8.15163 2.06811 -2.98756 -3.11598 -3.15003 +24.2265 0.098 0.134519 0.552934 -0.334675 0.289475 0.120102 0.609331 0.302432 0.244029 0.328583 -0.231974 -7.28122 -2.38466 -5.75007 -5.69618 0.62341 1.39089 -10.0289 -4.8557 -1.23803 -0.212354 +8.12873 -0.157 0.342026 0.647374 0.0720368 0.416352 0.535356 0.696785 0.59214 0.154183 0.249145 0.466527 -0.296549 -3.27215 -13.5804 -2.29792 1.95524 2.54534 1.69597 -1.20934 0.837954 2.90694 +-3.16035 -0.003 0.242586 0.0502579 1.0195 -0.368173 0.452923 0.674158 0.721774 -0.281118 0.0191273 0.448999 -1.80549 0.110218 6.09283 -1.91798 -1.32221 1.44204 2.67372 -5.5923 1.04145 3.86998 +-35.5854 0.047 0.161748 -0.635842 -0.46255 -0.234232 0.0259325 -0.382773 -0.000803015 0.305373 -0.525859 1.020273.64747 1.13474 3.31099 9.55929 2.60136 -1.13286 1.7687 9.19928 8.53728 4.14091 +8.48854 -0.038 0.601559 0.600984 1.02944 0.764976 0.595572 0.548898 -0.393957 1.3133 -0.0402905 0.12966 -2.01479 0.752782 -7.29609 -14.462 -1.45628 -1.47189 3.91984 -6.47259 -2.49058 3.70358 +-6.32734 -0.055 -0.0880079 -0.212033 0.10386 -0.841554 -0.348216 -0.739447 -0.137925 0.490141 -0.0237854 0.174336-0.274364 -2.40408 -1.38073 -5.2054 0.212669 -2.86996 -7.90863 5.50174 -0.33931 -8.20023 +16.5429 0.069 -0.147425 -0.375705 0.247726 0.28552 -0.0510798 -0.540718 0.404606 -0.494234 -0.554293 0.583863 -11.7043 -2.05344 -5.73003 5.60483 -0.568827 -1.87469 -0.645312 -2.746 2.42034 -7.49701 +7.92289 0.630 0.137563 0.507213 0.20011 0.990028 1.17139 0.0657366 -0.167888 0.63937 0.570073 0.258813 11.7589 9.79594 9.3935 9.40396 16.6707 12.3247 11.1718 2.14109 12.8751 7.62831 +20.5036 -0.001 0.0204708 -0.380855 -0.320686 -0.218736 -0.693059 -0.00719223 -0.237072 0.0253018 0.027525 0.2776945.79158 -6.02029 -3.89765 3.17448 -2.44047 -0.711078 -5.505 5.86117 -2.98572 -8.20425 +6.89531 0.045 0.402585 -0.826557 -0.373494 0.12683 -0.156503 -0.483085 -0.69419 0.391007 -0.892462 -0.189554 8.42067 1.92662 -1.17641 6.34801 5.18136 4.98192 0.600685 3.19303 1.11834 6.35213 +28.1315 0.054 0.0353498 0.57426 -0.0704633 0.179122 -0.69354 -0.497465 -0.699156 -0.273302 0.20018 0.447439 4.85099 -0.527163 -7.43739 5.07522 1.15885 -1.12884 4.11208 -6.16049 -9.0165 5.64011 +-5.52895 0.095 0.401586 -0.180426 -0.158369 1.48764 0.434029 0.682542 0.68981 1.03412 1.41437 -0.172119 6.34981 4.70762 7.79291 3.31517 0.0358004 -6.38532 12.1568 6.79848 -1.59975 -2.59776 +-0.521689 0.003 -0.735166 0.102111 -0.493007 0.186755 -0.149573 -0.0384252 -0.264468 -0.0307311 -0.149673 -0.7591465.79166 8.96173 -0.573049 11.0992 2.65776 3.73703 4.36946 -4.63343 -0.635207 -3.74122 +15.7047 0.023 0.43617 0.394469 -0.467654 0.2029 -0.430588 -1.02365 -0.292952 -0.0244639 0.342909 1.10757 1.7419 4.56662 7.33049 3.06844 6.62441 4.7261 4.14011 2.94774 4.74786 0.560755 +-3.68145 0.105 -1.3006 -0.81469 -0.561571 -0.881828 -0.104601 -0.692511 -1.01133 -0.178626 -0.57959 -1.15195 -2.41092 2.60697 3.20782 -0.0988833 0.492329 0.320069 2.74388 5.51454 5.40316 8.62783 +-16.5695 0.163 -0.584868 -0.0697934 0.191123 -0.0596991 -0.794517 -0.731714 -0.82909 -0.735119 -0.106879 -1.42157-0.427035 1.49634 -5.25446 -2.32157 -2.03164 -3.62136 -8.0784 -4.16007 2.6038 2.19971 +13.3955 0.018 -0.269525 0.284256 0.040992 -0.173622 0.246582 -0.130269 0.203537 -0.0429077 0.189925 -0.194708 1.85491 -5.45395 0.940652 -9.3283 -6.94395 -0.412207 -7.16952 3.18223 1.87452 0.811949 +-3.46233 0.514 0.521774 0.895593 0.350418 0.0629099 1.10105 0.853156 0.807454 0.581965 0.894264 0.406017 3.1398 15.1502 1.30312 3.23513 10.3868 9.99865 4.25512 2.62357 1.3088 2.26121 +24.8412 0.008 0.710147 0.126211 1.00527 0.395477 0.460532 0.475204 -0.170085 0.989459 0.268664 0.35764 -6.2037 -2.32218 3.31153 1.29643 -10.9024 -4.38066 -2.87542 -0.17953 1.73759 -8.714 +-0.856591 0.335 -0.974652 -0.459981 -0.610995 -0.768724 -0.157125 -1.43349 -0.684142 0.0552162 -1.07565 -1.06529 -3.70613 -7.07572 -3.99667 -4.89779 -5.38031 -0.134613 -0.721073 -4.09624 -6.36242 -2.78395 +11.2382 0.253 1.11321 0.659529 1.79665 0.849942 0.781559 1.053 1.23189 2.00304 1.14957 0.676971 12.0713 7.66115 7.46445 4.10681 8.79199 5.24511 3.11593 1.02446 1.74033 -1.38061 +-33.2365 0.444 0.0910077 0.108252 0.436213 -0.133518 0.396963 0.352299 0.0437032 -0.10473 0.00921647 -0.208974 3.60381 -8.33949 -6.16143 -3.80847 -2.51993 6.40334 -3.89535 -4.18214 1.47297 1.49241 +-24.0709 0.104 0.477261 0.568713 0.242769 0.308534 0.0890946 0.710274 0.544276 0.825153 0.669747 0.769277 -2.98741 -3.56079 -7.45403 -3.54357 6.83406 -10.5821 -3.98776 -6.35485 -8.48105 -4.54718 +27.6539 -0.037 -0.902584 0.487219 -0.496215 -0.222843 -0.508808 -0.0403082 0.175268 0.39143 -0.379139 -0.0812529-0.304915 -13.079 -1.47766 2.15933 -8.41381 -2.00048 0.292345 -7.22497 -2.20207 -6.73988 +11.0317 0.003 -0.247238 -1.04391 -0.808107 -0.613616 -0.015476 -0.849169 0.283971 -0.0473444 -0.664404 -1.1945 -2.2995 -6.20453 4.96423 -5.53368 -2.56231 -2.03644 -7.39908 -7.99366 -4.97121 0.459574 +26.2943 0.047 -0.329059 -0.00778234 -0.383429 0.080108 -0.231345 0.119886 -0.874176 -0.0107615 -0.267033 -0.48331210.9719 1.55473 5.87928 1.79139 12.15 4.69838 2.73559 7.50004 7.09099 0.50847 +-17.8201 -0.048 0.224901 -0.492521 0.172482 -0.352091 -0.568909 0.496416 -0.570933 -2.91599e-05 -0.319905 0.7882852.94444 4.6861 13.3262 1.40346 5.69942 1.01579 9.17697 7.23449 6.16958 5.39721 +-30.1437 -0.021 0.115222 -0.50483 -0.165301 0.917972 -0.356366 -1.02541 -0.275253 -0.151289 -0.106804 -0.545179 0.691283 -2.44264 -3.17382 -0.962583 -7.7556 1.01093 -2.49767 -2.1169 -4.28878 -1.95928 +-11.5906 0.231 -0.165128 0.284483 0.679113 0.0391742 -0.180131 0.872509 -0.0401787 0.240927 0.779764 -0.69153 -3.0487 -4.73878 -2.34782 2.24692 -8.40086 -0.558895 -2.88686 -0.16179 3.5654 -8.16208 +-23.0924 0.130 -0.574784 0.175771 0.819888 -0.50748 0.539022 -0.360158 0.641631 -0.321805 -0.284909 -0.0331085 1.4013 0.542889 -4.04521 0.762354 3.51194 11.105 0.697282 5.75295 2.31763 8.15668 +15.4823 0.259 -0.358246 -0.487886 -0.515137 0.101436 0.379712 -0.209374 -0.784419 -0.330317 0.0874495 -0.6520250.321123 7.28186 5.2521 7.52892 5.97159 -0.453424 4.21755 -0.45871 1.14945 7.08759 +-12.862 0.266 -0.847838 0.548827 -0.355959 -0.163987 -0.257846 -0.0716377 -0.590061 -0.182043 0.276001 0.385787-0.883215 -10.5243 1.13479 -1.71556 -6.57288 -3.003 6.02049 2.41911 -3.08448 -4.90085 +-3.95441 0.294 -0.475102 -0.366642 -0.220269 -0.872986 0.0828484 -0.495751 -0.0639666 -0.528452 -0.567485 -0.324172-1.11717 -4.03782 -7.60136 2.47449 4.579 -2.28127 -0.545007 -1.98324 -3.82297 -0.685635 +5.54384 -0.031 -1.34152 -1.16389 -0.216734 -0.275704 -0.370072 -1.39041 -0.668894 -0.570782 -1.05802 -0.167771 2.58276 10.891 4.40916 12.4951 1.92982 10.7488 3.26585 -0.250259 9.7694 5.23776 +9.60623 -0.006 -0.550753 0.15471 -0.177289 0.11653 -0.15045 -0.639511 0.318426 -0.771361 0.417958 0.272348 4.86059 3.14217 2.5301 3.97129 8.24283 9.47241 4.01724 6.82168 6.96159 15.3333 +-10.4022 -0.008 -0.19615 -0.254906 -0.550218 -0.538626 -0.305762 -0.596324 -1.00069 -0.475577 0.312173 -0.147458 -5.76113 -8.82312 -10.098 -8.79932 -4.85593 -0.630115 -8.36823 -4.13272 -6.78752 8.38389 +-7.9916 -0.260 0.278116 -0.60186 0.168962 -0.251986 0.558443 -0.580179 -0.185682 0.452524 0.392727 -0.0353216 10.3213 1.41408 1.48401 3.25285 -4.24142 1.96742 5.13497 -2.00469 1.73159 -0.774115 +-31.9231 -0.015 -1.09225 -0.127329 0.154512 -0.0706862 -0.590358 -0.22742 -0.615714 -0.720993 -0.0510963 -0.476577-6.03213 -0.314307 -0.751143 -12.2916 -6.07228 -10.9253 -7.93202 -0.378107 -3.86303 0.718152 +-10.9452 0.012 0.348305 0.954368 0.682275 0.892211 0.487404 0.318265 1.08763 0.998395 0.865185 1.25731 -9.12967 -2.28121 -1.57797 -2.23743 -3.97031 -1.45246 -5.37147 -3.12425 -5.42988 7.39314 +-12.065 0.136 -0.208087 -0.0705531 -0.354055 -0.691023 0.127595 0.0968828 -0.131823 -0.656307 -0.763868 0.0857675-6.88023 -1.12613 -4.86992 0.965022 -1.37164 -8.21268 -4.0904 -2.62833 0.409169 -3.52964 +-12.7603 -0.081 0.308559 0.299012 -0.624936 -0.117283 0.357298 0.274747 -0.467052 0.300612 -1.36311 -0.482307 0.0188954 -4.61329 2.16979 9.78189 -0.196177 3.44118 1.24706 5.90009 5.10406 8.65579 +-10.6735 0.122 0.541224 0.113578 0.537014 -0.0641264 0.687895 0.202598 0.401557 0.919655 0.684904 0.392905 -3.12161 -2.2097 -6.76367 -6.13316 -0.969094 0.545716 1.86523 -1.18902 -2.76134 0.778111 +-5.87328 0.261 0.302369 -0.389439 0.750626 -0.185537 0.532017 0.404054 1.38279 -0.466796 0.976239 0.416341 1.7716 -2.5396 -6.77782 0.274495 -1.81334 -0.425399 -0.364747 -7.5493 -1.58385 -4.99845 +32.6369 -0.039 -0.353811 0.0989344 0.115225 0.0835225 -0.486818 -1.08389 -0.0812642 -0.127329 0.433464 -0.6517097.0478 4.82623 5.57441 4.90197 5.32122 8.84235 6.64881 5.94762 12.3154 4.41575 +15.4275 -0.016 0.488595 0.123887 -0.837476 -0.103521 -0.388786 0.127154 -0.207225 -0.259404 -0.347649 0.119488 8.65649 -0.624774 0.642596 7.84633 -1.32432 6.75992 2.6427 7.72012 -6.89597 6.95798 +-3.35631 0.063 1.01136 0.784855 1.16209 1.18603 0.952557 0.746278 0.665281 1.61848 0.823884 1.57656 6.86925 3.63981 1.58979 -1.79659 9.24708 8.85094 10.8505 9.12427 0.70198 2.08643 +3.50884 0.182 0.0979738 0.0147295 -0.770136 -0.551007 -0.375349 0.779887 0.417625 0.0399028 -0.252483 0.07075631.84933 10.8251 0.213388 3.79955 7.3784 -3.9103 7.60269 3.97119 8.22985 5.22069 +-3.09587 0.118 -0.792505 0.22555 0.0820694 -0.468442 -0.329103 -0.292303 -0.310438 0.0680415 -0.165894 0.396078 7.02522 9.67748 16.5472 17.8735 10.3442 9.16839 16.855 13.2195 14.889 15.2203 +-1.43666 -0.038 -0.393689 0.0256909 -0.45998 0.313394 -0.866859 -0.126445 -0.584236 -0.810833 0.0950849 0.103721 3.50983 10.0928 5.60024 6.86582 6.09003 3.4617 4.65031 5.99263 12.5819 7.23423 +2.18541 -0.010 0.448863 1.15653 0.516351 -0.115754 0.609025 0.17602 0.622066 0.566933 0.00325097 0.360881 -4.94935 -5.16411 -7.67312 -7.81529 -4.70922 -1.14668 -4.79327 2.13846 -0.111811 -2.48463 +3.77109 0.281 -0.47738 -0.391086 -0.193133 0.0206036 -0.330453 -0.0956475 -0.024072 -0.358185 -1.15069 -0.759041-7.77512 -7.90173 -2.94902 -10.6878 1.11437 -5.72925 -0.790808 -6.89036 -8.18809 -3.19794 +13.32 0.076 -0.457375 -0.785506 -0.365526 0.10367 0.125322 1.01869 -0.27653 -0.61928 0.497827 -0.0306434 -4.10769 -2.74075 -2.90939 -1.89361 -6.28826 -6.7518 0.146198 -5.6601 -10.4922 -0.545101 +9.54131 -0.008 0.293219 0.46122 0.497017 0.452457 0.370037 -0.0189176 0.473748 0.0714409 0.620237 0.355862 11.8142 8.48518 11.7757 10.3217 9.60887 14.3046 10.7943 10.9227 12.1581 11.5396 +-15.2376 -0.133 0.171055 0.910285 0.0195287 0.103176 0.075502 0.225184 0.708613 0.836259 0.219635 0.268394 -0.675039 2.01782 -0.489061 5.43883 -5.58283 0.274933 2.46522 7.13829 -3.05853 1.13499 +22.7896 0.343 0.315985 0.315612 0.258642 -0.0475534 0.97817 0.175253 0.971176 0.722288 -0.482387 0.379563 -2.41657 -0.430631 0.664298 1.92764 -10.6528 0.474333 -3.80721 -0.829673 2.60926 -3.38754 +34.7366 -0.010 -0.31978 -0.0630581 -0.745982 -0.31815 -0.251168 -0.553424 0.198732 -0.6607 -0.149224 -0.117919 -3.70689 -5.86202 -3.93024 3.02897 -5.94159 -3.37449 -0.0604506 4.93219 1.47519 -2.1823 +-14.7658 0.034 -0.274206 0.258775 0.421818 0.251032 -0.172914 -0.132187 -0.559894 -0.642612 -0.0812426 0.590965 8.95196 4.19892 2.99115 11.7394 -1.97399 11.8651 4.3186 -2.66548 4.87484 3.40971 +23.2679 0.147 0.292576 0.201613 -0.210459 0.92126 0.272561 0.394367 0.205946 0.948164 0.212594 0.22139 4.24775 0.260685 5.23221 7.61982 -2.66336 -0.628298 2.62129 7.22859 -1.5974 3.96612 +12.257 0.160 -0.354066 -0.168025 -0.240766 -0.319263 0.0586319 -0.366633 -0.821572 -0.237238 -1.06387 -0.641163-5.14226 1.73619 -2.94754 -2.8161 -0.982226 1.47511 -4.67812 -5.34039 -9.45843 2.11479 +1.01692 0.063 0.283818 0.665353 0.305946 -0.0390276 0.981873 -0.15499 1.39389 0.228356 -0.170262 0.823611 -1.82841 1.33135 6.46101 -4.38305 -5.61138 5.25522 -6.34835 1.92159 -1.63893 -4.81415 +9.79274 0.162 -0.330613 -0.987523 -0.676136 0.125332 -0.00559682 -0.831429 -0.8247 -0.988929 -0.455375 -0.383653.80461 12.943 4.1525 3.06477 9.45192 -5.82209 11.191 -6.03816 11.8775 2.94489 +22.9525 0.038 0.346569 -0.163368 -0.19424 -0.66662 -0.369276 0.100693 -0.519783 -0.126102 -0.3372 -0.121203 -5.15436 -3.192 -5.41414 -5.62532 5.0025 -5.67419 -6.88871 0.788091 -1.2605 4.65084 +-18.0834 -0.001 -0.199043 0.433161 1.06185 0.720944 0.0356625 0.519153 0.71735 0.714149 -0.264736 0.422694 -2.29975 0.293738 2.03024 -5.89062 0.0679365 -12.0688 -3.13668 0.517999 0.449684 -1.68818 +-0.722164 0.145 -0.465697 -0.354073 -0.0595311 0.0523721 0.520111 -0.0430948 -0.41352 -0.590402 -0.236382 -0.0636292-3.41495 1.73977 -2.31294 -5.85043 0.474787 0.597218 -1.19199 -0.875024 -6.3708 -5.67654 +0.769805 0.185 1.00544 0.327542 -0.138965 0.150899 0.372581 0.104898 0.531017 0.102186 0.681903 0.458178 4.94209 0.26559 -3.15533 11.6881 11.0404 3.07671 11.1944 7.18452 11.8817 2.98574 +21.4487 -0.129 -0.162705 -0.485027 0.0770257 -0.728792 -0.04612 0.581534 0.530062 0.256702 -0.430708 0.131064 2.06922 -3.54984 -9.40967 0.279024 -2.95649 -0.425448 1.09398 -0.0587079 0.391021 0.209272 +32.3944 0.124 0.742333 -0.247584 0.299219 -0.749981 -0.953995 -0.719539 -0.664072 -1.02221 -0.321718 -0.126226 -2.68281 1.54994 -4.47193 -8.1604 -1.3457 -1.42767 -2.51969 -1.57165 -3.35499 -9.85086 +-1.70231 0.050 0.676983 0.219563 0.608952 0.821637 0.373441 0.599701 0.357406 -0.359363 0.127804 -0.351604 10.8983 8.72999 8.74048 8.67539 6.87554 10.147 14.39 9.96592 17.2132 14.0094 +21.4179 0.004 -0.166757 0.235912 0.149197 -0.571767 0.434539 -0.226861 0.160352 0.211988 -0.316149 -0.165946 -5.56511 -0.744479 -13.0266 -4.83532 -0.842446 -6.12657 2.11276 -11.7483 -3.92915 -8.42722 +19.5448 0.047 -1.68501 -1.39942 -1.09892 -1.05547 -1.55978 -1.41077 -0.85646 -0.518189 -1.45234 -0.104976 3.77461 -9.12124 -0.149773 1.99897 -4.6564 -2.28913 -0.629571 -1.62393 -3.06005 -2.78897 +-19.735 0.026 -0.245523 0.103719 0.376348 -0.892891 -0.994713 0.243609 0.482914 -0.549476 -0.157715 -0.74553 4.00404 2.76808 0.346789 3.27133 7.38298 -1.32444 7.08867 0.0136968 2.94436 -0.28365 +30.5279 0.263 -0.0191626 0.904107 0.416502 -0.172739 0.40976 0.162091 0.781148 0.0636505 -0.103667 0.139144 -0.623441 2.63294 -7.57264 2.15788 -0.110978 0.238465 -0.283956 2.41959 -1.68667 -4.57796 +29.4904 0.142 0.852321 0.511367 1.1287 -0.2422 -0.055046 -0.183508 0.53907 0.26995 -0.0349281 0.225567 -2.35317 -6.40793 -4.52561 -6.25249 -7.24017 -5.92601 0.862545 -2.05038 -9.43122 -9.48084 +-11.0326 0.139 -0.689801 -0.592855 -0.269152 -0.157211 -0.283042 -0.750576 -0.0845783 0.39367 -0.128427 -0.9846670.104239 -3.31191 -6.1403 -6.98524 -5.14294 2.37636 6.50647 -5.36879 0.761715 -10.043 +19.2553 0.104 -0.181521 -0.423752 -0.0238594 0.0324673 0.51898 -0.175746 0.821713 -0.609854 0.788669 0.0193771 -5.9924 -1.62779 -2.25429 -3.52924 -1.17697 -3.53576 3.36873 4.58375 -3.58009 0.687499 +-9.19445 0.126 0.575166 1.08468 0.318037 1.18141 0.0847908 0.659361 0.74722 0.543122 0.22371 1.0246 12.0766 7.68244 11.1493 6.24253 5.88639 8.41762 14.792 18.379 15.6135 7.33279 +10.6943 0.219 -0.458745 -0.143579 0.897458 -0.082143 0.304228 -0.102517 0.707828 0.376103 -0.52054 0.151516 0.298914 -6.54062 -3.68956 -5.99706 -5.0398 0.764192 -5.53007 -3.46341 0.18894 3.53895 +12.3994 0.114 -0.0928901 0.702241 0.56863 -0.0148701 1.37929 0.17636 1.05797 0.0103272 0.416586 0.429401 9.37802 -2.77104 -0.36261 3.13143 8.61679 5.86769 0.748599 4.21909 -6.45924 4.67513 +13.4045 0.254 -0.240789 -0.0888207 1.0133 -0.206832 -0.516782 -0.251572 -0.308733 -0.569341 0.231938 -0.262642 -0.46391 -6.7148 -0.683778 -6.71321 2.16247 2.649 2.24788 -7.21652 -5.33205 3.22862 +-24.1667 0.036 0.0879353 -0.343437 -0.226372 0.0444418 0.0410081 0.166221 0.442272 -0.312584 -0.0746198 0.731824-0.705769 0.972306 1.94705 0.31108 -2.43037 -12.0491 -3.60545 5.20344 -5.81555 -5.12128 +4.68718 0.062 0.601354 0.959563 0.854723 1.65317 1.4413 0.925379 1.45743 0.954698 0.868786 0.68243 -3.60189 -11.7453 -1.69703 -0.274077 -1.92019 -5.77098 -3.4529 -14.7372 -1.12542 -1.66444 +-13.0735 0.269 0.954879 0.925306 0.522141 -0.303932 0.269491 0.904887 0.383126 0.456866 0.70028 0.650547 6.1435 1.23709 5.95265 6.26131 -2.03744 2.28833 5.59024 7.03955 -1.34266 -1.31989 +1.7873 0.050 -0.738583 -1.2287 -0.00467607 0.4307 -0.747435 0.547643 -0.0373029 -0.808532 -0.685262 -0.2352 10.7126 -0.53902 1.78874 6.4529 3.93548 3.95198 6.78751 3.17829 10.1779 2.38458 +-1.79725 0.054 0.375588 -0.805145 -0.768696 0.325854 -0.113681 -0.113718 0.0726185 0.333002 -0.164107 0.136166 0.0927901 1.15183 -1.86984 -3.97739 -2.47844 -1.12217 -6.12011 8.97318 -8.30398 -0.670868 +-22.0056 0.072 -0.107853 -0.209935 0.24706 0.342612 0.611086 -0.711079 -0.450319 0.105716 0.508627 0.222293 0.101322 -2.28421 0.775316 4.96493 -2.11497 -1.76633 -2.33188 -6.40896 -1.81753 -1.81719 +6.05275 0.129 -0.229105 0.0886448 -0.030637 -0.377458 -0.554469 -0.34923 -0.629304 -0.256083 -0.19245 0.136657 -2.66133 -3.81966 -5.86394 -0.972126 -11.283 -3.45663 -2.69429 -2.08491 -6.74585 -11.0536 +-16.7849 0.254 0.789529 0.185641 -0.109795 0.506512 0.72967 0.858902 -0.512685 1.43332 0.720048 0.19256 -6.36966 -6.34542 -2.07096 -5.30196 -6.69316 -3.25016 -4.02759 -3.34256 -5.83538 -5.35259 +-1.13528 0.051 -0.374414 -0.106765 0.00851735 0.186483 -0.418122 -0.128033 -0.624639 -0.255918 -0.361683 0.291842-4.07516 1.52215 -4.36611 -3.31792 9.06356 -5.95602 -7.45892 -4.46966 -1.48647 -4.75288 +13.1126 0.093 -0.223807 -0.964159 -0.858762 -0.385089 -0.722288 -0.0560184 -0.793052 -0.607761 -0.101257 -0.7838894.20147 6.13206 -1.5799 3.76006 -1.72085 0.952024 1.08821 8.21537 5.09241 -4.68188 +3.55364 0.117 -0.167386 -0.162272 -0.612961 -0.431449 -0.382328 -0.218811 -0.582922 0.154513 -0.283862 -0.0607226-3.82608 -6.88869 6.15455 -4.55679 -7.71361 -7.92865 -7.37546 -2.70737 -8.99593 -1.21304 +-22.6424 0.125 -0.0991053 -0.322137 0.0606672 -0.0751139 -0.0465937 -0.055926 -0.067911 -0.245925 -0.356431 0.6380290.32439 -5.641 -1.82754 -4.16499 1.71013 -0.958917 -4.46436 -8.63922 -3.48049 -3.18812 +10.9488 -0.164 -0.161131 0.675896 0.497338 0.709184 1.17392 0.758443 -0.506949 -0.0801665 0.624999 0.8436 1.86242 -4.62257 -6.04607 1.6335 3.82142 -0.428671 -2.35008 -4.26829 0.126091 -2.1367 +-13.114 0.401 -0.320754 -0.801234 0.312336 0.155558 -0.526034 0.299385 -0.494443 -0.153558 0.32604 0.150681 -6.17579 -2.37409 -3.56578 -6.24564 -5.96098 2.1115 -6.61045 -4.26762 -4.95631 7.31146 +-28.4599 0.276 0.215953 -0.948382 0.0107865 0.171681 -1.06352 -0.0308668 -0.234839 0.0200455 -0.554334 -0.7155481.88934 -0.274767 -5.5393 -7.89825 -5.44669 1.08379 -0.346899 -4.39497 -6.07517 -9.84673 +11.8705 0.324 0.419706 0.51392 0.08724 0.57409 -0.0858795 0.163561 -0.154479 0.57848 -0.0799282 0.786217 -9.21237 -0.100035 2.31701 -3.91645 1.32011 -6.9786 -9.31149 0.901541 0.792294 -4.21191 +22.1809 0.111 0.304488 -0.585166 -0.0136605 0.058837 0.365657 0.555657 -0.264013 0.819064 -0.266043 0.095637 14.2388 8.46543 8.84781 8.64485 10.7395 14.2505 11.3974 6.5064 15.6438 11.2555 +-4.51845 0.323 0.967041 -0.198991 -0.0624871 0.0107181 0.95128 0.00122453 0.0874974 0.308019 -0.20527 -0.245037 -5.32576 7.80256 -2.84489 -4.97944 0.627615 -6.29373 -8.44232 -2.50951 1.38952 -11.8529 +6.39324 0.057 -0.331446 0.414798 -0.20663 -1.16746 -0.519401 0.125373 0.260866 -0.0102934 -0.434879 -0.172328 1.86023 -11.4312 -1.44503 -6.0532 -2.70715 -2.75622 -1.02164 7.35896 -3.62269 1.56303 +-11.0215 -0.004 -0.69204 0.335741 0.0354332 -0.34984 -0.0622042 0.389201 0.0849153 -0.466802 -0.591427 0.505766 -3.37437 0.174257 -4.8976 -1.2411 -0.249044 2.55827 -11.4232 -0.627463 1.06582 -4.35044 +26.333 0.055 -0.219487 0.699687 0.398886 -0.0111278 0.668165 -0.420674 -0.270604 -0.362551 -0.859983 -0.0831362-6.85099 1.55144 5.74163 -12.4052 -5.24868 -3.83932 -2.31439 -10.8736 -3.66321 4.11897 +4.80368 -0.101 -0.0129251 -0.959623 0.368651 0.563199 0.0756959 -0.391155 -0.0721374 0.00898519 0.645763 -0.211441-2.61942 -4.18798 -1.59651 -2.72878 -0.573693 -8.82039 0.426889 -0.6637 -4.95309 -1.99326 +20.97 0.228 -0.709471 -0.490484 -0.552807 0.062959 0.0435437 -0.0526748 0.0609524 -0.574194 0.579698 -0.4632232.38815 -7.26015 -6.80788 -5.04713 -7.49903 0.144241 -1.74519 -5.53782 0.348749 -8.0935 +-14.654 -0.005 0.208939 -0.716868 -0.571624 0.396239 0.586698 0.0382854 -0.486816 -0.553427 -0.638674 0.241988 -3.56571 1.51029 2.8628 -9.07391 -3.93256 -6.44412 -2.47192 -5.62221 -8.72378 -0.399526 +7.66532 0.060 0.479199 0.0471299 0.237947 0.426059 -0.230839 -0.518084 0.123225 0.66463 -0.221705 0.558203 -2.55741 2.22969 -9.06104 -0.651954 -5.66321 -7.24033 -5.6657 -10.4043 -1.3301 -6.52106 +-5.11117 -0.034 -0.320527 0.00455315 0.289473 -0.357354 -0.56985 -0.30037 0.0567359 -0.0707844 0.3592 -0.815123 -6.16015 -6.61765 3.90774 4.5212 -7.56724 3.55774 2.33137 -0.00529207 2.20792 -2.14094 +-14.7653 0.054 -0.917505 -0.00798906 -0.772607 0.144931 -0.0192555 -0.392525 -0.972746 -0.355053 -0.0560084 -0.9004225.68103 1.58921 9.93858 7.57634 4.56501 4.00134 7.7144 1.72434 2.56972 6.01326 +-17.1933 -0.068 0.380894 0.731854 0.0922628 0.821108 0.650916 0.777959 1.18863 0.199128 0.700408 0.848262 -8.23614 -2.30083 -2.53304 -2.14451 -5.44275 -2.99141 -7.33911 -3.1403 -4.41222 -5.30478 +3.52973 0.047 0.324019 0.162674 0.53885 0.6293 0.321297 0.103199 0.778576 0.114631 0.660228 0.456326 4.97992 -7.56789 -4.94646 4.27591 -4.0572 -2.28741 -7.09761 3.70019 1.9421 -6.64605 +-4.92449 0.094 1.05085 0.921992 1.0445 0.596359 0.724706 1.34143 0.640039 0.894245 1.16439 1.04759 3.8445 1.34307 1.86446 1.04104 4.48143 6.61596 13.4619 2.15923 5.5225 -0.707516 +8.73379 0.011 0.547642 0.811306 0.844214 0.204027 0.490452 1.16908 1.46544 0.775182 0.171317 1.56708 -2.29934 -0.12699 -4.39312 -3.87152 -4.35433 -3.79645 -1.33389 -0.416678 -1.08249 0.206546 +-23.5705 0.031 0.14034 -0.758958 0.697386 -0.458802 -0.0300294 -0.0210416 -0.728399 -0.554868 -0.636925 -0.439501-3.18063 -1.35424 -5.69644 -2.33469 -0.882066 2.53222 -8.03785 -6.97033 -8.02523 4.59205 +-2.75746 -0.079 0.101547 0.491154 0.00521081 0.608162 0.685673 -0.0232369 1.24837 0.385078 0.876497 -0.903194 -0.963794 0.850479 -2.07681 4.87449 -7.45519 -1.42153 2.535 -3.00918 -6.61258 -1.65032 +3.74231 0.225 -0.911101 -0.285125 -0.0957217 -0.145122 -0.210564 0.119669 -0.174574 -0.431946 -1.18379 0.603131-4.78345 -3.73672 -9.25402 -0.422497 -6.16951 -6.22239 -0.475782 -6.76988 -4.53415 -2.5741 +10.1843 -0.041 0.798664 0.127753 0.802954 0.479894 1.04296 0.178587 1.15493 0.159311 0.252408 0.249618 -5.61024 -4.67626 -1.73456 -1.77783 -5.39622 -1.84963 -1.42826 -5.82403 1.43939 2.63866 +-10.2904 0.088 0.681014 -0.115267 1.49154 1.24119 1.80895 1.50032 0.29056 1.43886 1.09969 0.725874 6.07327 9.32947 9.48029 11.9904 11.4499 4.5149 0.507698 13.1855 9.60974 10.6709 +2.03387 -0.124 0.104006 -0.0774606 0.317202 -0.127557 -0.358262 -0.111505 0.0184427 -0.763872 0.0898268 -0.7618890.340429 0.167668 -0.308335 5.20489 -0.589366 -3.87727 -5.81621 -7.28617 -8.68718 -5.77494 +28.4827 0.208 -0.549598 -0.247288 0.186206 -0.6651 -0.637433 -0.354484 -0.994638 0.447119 0.539227 -0.0650231 -4.01655 -0.79534 -0.983634 -6.54924 0.560599 -2.89387 4.64121 -2.95695 -13.8414 -6.54637 +8.31902 -0.018 -0.629687 -0.451319 0.0611172 0.331762 -0.0619341 -0.308739 0.0889889 0.816501 -0.329107 0.463915-7.39935 -7.13863 -1.74351 -3.84859 2.09086 -5.55606 -0.416976 -5.61497 -1.16214 -2.67304 +3.32587 0.053 -0.26567 -0.631894 -0.414948 0.470637 -0.11815 0.505566 0.320591 0.268905 -0.0522411 -0.0537291 5.42849 5.11785 -1.7444 2.59029 8.07904 5.8815 0.854383 9.13519 4.40357 6.66091 +-20.3284 0.027 -1.21881 0.0568215 -0.244435 0.0049717 -0.205328 -0.146145 -0.24729 0.384431 -0.43709 0.616497 9.11332 2.11881 8.55283 3.79681 4.92776 9.07252 0.0327992 2.12726 10.9177 -2.91178 +12.2868 0.025 0.777543 -0.713737 1.32242 0.722332 0.501579 0.572048 0.161272 0.386533 0.497149 0.331017 -4.03757 4.9704 -0.393517 -10.1371 0.307496 0.838061 -2.37025 -1.04318 -5.5763 -5.38508 +-8.18816 -0.049 1.30624 0.845082 0.0839782 1.47222 0.541263 1.636 1.3016 1.28226 0.945871 1.32867 -8.36416 -7.8663 -0.933833 0.637883 -1.2532 -3.08452 -1.3434 -3.55082 -5.24957 4.8509 +13.7521 0.076 -0.0639159 -0.278948 -0.254236 -0.36582 -0.345798 -0.297764 -0.122647 -0.00442774 -0.234608 0.372989-4.07529 2.81474 -1.51866 -5.86524 -1.92638 -3.42585 0.755154 -7.59234 0.397398 -3.62909 +33.8408 0.170 -0.0196957 -0.267862 0.108637 -0.707019 0.145002 0.39782 -0.349358 -0.344498 0.391622 0.236983 0.419191 -4.36275 -5.11574 -0.740869 -9.50178 -10.9415 -2.05345 1.82926 -1.94082 2.96985 +-3.13034 -0.036 -0.203306 0.37513 -0.404636 -0.0664076 -0.331605 -0.0536288 0.202531 0.537001 0.00361743 0.3011836.18931 -0.0820069 6.054 -8.04799 1.27892 -5.06709 4.84595 -4.51189 2.81337 -5.85898 +14.8905 0.070 -0.327184 0.143735 -0.35681 0.229339 0.340813 -0.533964 -0.303215 0.277241 -0.408969 -0.306395 0.722038 4.0329 -1.83595 8.90114 0.0432136 0.999342 -2.0159 1.28592 -0.863236 -1.3175 +-8.24474 0.072 -0.257232 -0.103162 -0.201532 -0.622597 -0.538754 -0.385642 -0.797509 0.029478 -0.115237 0.265339-5.86014 -2.27326 -1.51136 -7.19345 -4.09614 -2.85379 -1.02485 -8.03648 3.48911 -4.92436 +-37.76 0.138 0.0746585 0.0303555 -0.44689 0.240784 -0.753825 -0.582679 0.12761 0.172323 -0.737528 -0.536505 -7.26998 1.1909 -5.20929 11.0267 5.72097 2.09304 0.961906 9.9466 7.00245 7.08697 +11.8911 0.091 0.115475 0.323007 -0.18631 0.7127 0.0939212 0.0356243 -0.479019 0.0222664 0.181474 -0.409572 -0.518344 -0.799739 2.02385 4.04844 1.31457 2.63633 -8.65195 0.444977 2.56348 -2.10024 +-3.14324 0.186 0.706924 0.276251 0.992647 0.341994 0.890517 0.323542 0.410287 -0.0983789 0.738353 0.827875 -1.26162 -0.602871 -4.71992 -7.98705 -6.89308 -8.77446 -12.5416 -4.52335 -8.0774 2.99512 +22.5964 0.244 0.102333 -0.588053 -0.00438463 -0.746126 -0.655259 -0.512235 -0.945804 -0.202982 0.00215719 0.6829693.01084 1.89339 0.567035 8.02127 1.15623 4.55638 3.54984 2.26123 8.78799 7.78346 +20.546 -0.006 -0.434482 -0.372474 -0.272781 -0.442128 -0.145032 -0.629604 -0.165112 0.0889264 -0.0612324 0.5918761.28092 -5.60558 4.236 -9.18635 -4.47683 1.14803 -4.16941 -0.39177 -6.26675 -0.828211 +20.0816 0.339 -0.00122051 -0.730375 -0.423106 0.230032 -0.680915 0.331537 -0.946029 0.125255 -0.116808 -0.8035270.964094 0.180216 8.44131 3.13153 4.76949 7.97434 -0.605472 1.80824 11.0416 3.15808 +3.24478 0.094 -0.607432 -0.724489 -0.47406 0.104582 -0.990079 -0.107315 -0.746383 0.404599 -0.613359 -0.496958 1.15306 -3.01713 2.69466 2.12893 -1.6827 1.25995 16.3636 5.98064 1.94598 12.3663 +-10.0807 -0.115 -0.110369 -1.13617 -1.38632 0.238545 -1.27061 -0.72735 -0.668637 -0.189315 -0.274392 -0.0605696 2.0989 0.240604 4.68453 13.423 3.46586 -2.03755 2.39965 2.87634 2.19826 7.82629 +-16.9561 0.122 -0.0428129 0.73346 -0.177744 -0.090158 -0.511214 0.427863 0.731725 -0.0805177 -1.08586 0.176986 0.254921 -2.28829 9.92713 6.62943 10.3797 2.9613 3.13609 0.409721 5.25431 -3.95226 +26.1604 0.016 -0.870187 0.831453 -0.40647 0.0175998 0.132149 -0.373789 -0.0293682 -0.754571 -0.0985347 -0.0291529-0.0064269 -0.228998 -4.17127 -6.53589 -10.6959 -13.5657 -1.99602 -4.78072 -3.71219 -0.525281 +-1.96996 0.143 0.864085 0.736124 0.384295 0.55775 0.302583 0.471052 0.11375 0.0493869 0.256125 -0.103964 -2.5024 -3.44885 -2.70679 3.29099 -6.11425 -4.30599 -5.02309 -2.91583 -2.98363 -0.479894 +-17.015 0.173 -0.288505 0.107916 0.287665 -0.0499334 -0.469858 -0.0402156 -0.401066 -0.292173 -0.861074 0.2696613.91254 -4.81911 1.06949 7.74795 5.97029 4.13139 9.21034 7.07115 -0.989183 2.67751 +-29.8151 0.154 0.151598 0.156234 0.3978 0.297931 -0.0713417 -0.117013 -0.167094 -0.627104 0.745183 0.53069 -4.10005 -5.78404 -0.0667522 -6.93662 -3.54979 -2.8534 -5.114 -6.03121 -7.47971 -5.0939 +3.95078 0.085 0.493342 0.103026 0.662251 0.376671 0.303351 0.409399 -0.0455092 0.502978 -0.11373 0.0448678 0.860315 0.989794 4.79449 3.64883 10.3347 -3.78523 6.24976 8.66795 4.77134 1.72069 +-5.04797 0.243 0.0955661 0.250954 0.51232 -0.349022 0.540611 -0.475614 0.189365 0.0799171 0.0664887 0.00378839 -4.3262 1.79892 -2.64322 -8.81943 7.71695 -3.70826 -3.36781 -3.56156 3.03919 -3.0568 +7.01715 0.097 0.595151 0.336155 0.384988 0.60501 0.780777 1.1373 0.437823 0.612155 0.209935 0.734293 -1.91587 5.62196 2.15036 -0.583323 -9.77597 9.49361 1.8478 -1.02883 -10.7512 -8.20823 +-34.8853 0.195 0.703331 -0.387447 0.590871 0.0378799 0.966757 1.20654 0.916159 0.197749 0.541319 0.680905 1.25356 5.56489 -1.19232 -10.0047 -8.56135 -6.69456 -0.381237 -8.57705 -3.73315 -7.34611 +5.7906 0.284 -0.155462 0.0736216 -0.651382 -0.108133 0.240547 0.193384 -0.300835 -0.533085 -0.0250832 0.061417512.2352 13.8258 1.86644 17.622 6.48781 8.31745 10.6294 13.7564 11.9359 13.2611 +18.139 0.397 -0.354682 0.286634 -0.0989387 -0.339726 -0.310828 -0.417945 -0.380983 -0.322247 -0.0549752 -1.02396-3.02454 -1.74949 1.7821 -0.820656 -10.5214 -2.06775 -7.79816 -5.5058 -0.357927 -5.33707 +-4.86808 0.065 1.02161 0.384561 0.132475 0.828429 1.07264 0.997685 0.832835 0.655363 0.362492 1.20635 1.43057 -2.65724 -3.75102 3.12458 -1.53672 -6.60459 3.72549 1.99585 -2.51478 1.5052 +-3.63009 0.140 -0.338215 -0.283932 0.165162 -0.284158 -0.850914 -1.01482 -0.619984 -0.426794 -1.24958 -1.17514 -5.16822 -8.82486 1.84671 -9.27857 0.123377 -1.65076 -2.35005 -3.28204 1.44195 -7.53947 +-5.49306 0.158 -0.178239 0.276607 0.367992 -0.4977 -0.203538 -0.0946781 -0.331087 -0.429152 0.664266 -0.211637 -4.37919 -3.12829 -2.88064 -7.13506 -4.00833 -2.47869 -6.76275 -2.72482 4.31013 2.80751 +10.523 0.171 -0.318908 -0.919701 -0.530735 -0.822976 -0.309642 -0.316208 0.241389 -0.741835 -0.612201 1.20705 5.82182 4.95128 5.12156 5.34521 2.20566 4.43979 0.893681 -1.87661 1.27129 10.4642 +7.63491 0.300 -0.0860077 -0.351942 -0.0992653 -0.506376 -0.466891 0.366747 -0.403215 -0.0598439 -0.289224 -0.715665-5.06127 -9.92737 -7.23548 -5.11892 -0.266422 -8.2429 6.048 -4.37377 -6.31926 -3.53306 +6.86284 0.156 -0.129596 -0.41411 0.213933 0.354658 0.0152813 -0.731456 -0.0311792 -0.40754 -0.477733 -0.962908 7.36557 3.78248 5.00661 1.56053 11.545 7.0023 6.87288 5.72743 8.14576 -3.23857 +12.5502 0.211 0.941942 0.804187 0.143146 0.273501 -0.132323 0.323393 0.546273 0.901292 0.244226 0.268751 -6.15789 -1.43823 1.19851 -9.42376 1.69262 -7.6679 0.447193 6.02904 -7.30241 -6.30204 +23.5147 -0.018 0.65903 -0.881053 -0.00131759 -0.672904 -0.121097 0.247176 -0.0559668 -0.277479 -0.110191 -0.0698462-4.51241 -7.88505 -2.13629 -2.4461 -8.45584 0.533389 1.95099 -5.17467 -5.75958 1.33859 +-24.6313 0.097 -0.733575 0.179389 -0.569561 -0.78728 -1.58618 -0.686298 -0.626194 -0.528479 -0.514322 -0.483812 4.8916 4.46498 10.4841 -3.84245 6.32665 11.8782 11.2863 0.975527 -0.0189115 6.12436 +0.558252 0.095 0.117083 -0.662857 0.0920187 -0.508322 -0.200484 -0.442791 -0.0346808 -0.328855 -0.977643 -0.4603898.21964 -2.99267 6.91571 1.67526 4.85477 2.34917 3.78473 3.31599 -4.58042 7.848 +19.8528 0.024 -1.18394 -0.556575 -0.224951 -0.713781 0.233911 0.132175 -0.165536 0.141567 0.421532 0.106526 -4.02319 -0.906209 -3.17303 -1.91073 -7.55881 -1.40679 -1.09413 -2.17164 -5.17982 -3.41563 +-3.16786 0.115 0.0532202 0.250372 -0.19238 -1.00431 -0.273084 -0.527861 0.723273 0.138562 0.377527 0.35969 -5.2636 -7.42773 -5.31583 -2.8662 2.12088 1.40036 -2.59431 -8.37857 -6.35538 1.23857 +20.6994 0.085 -0.238841 -0.79081 -0.5672 0.173347 -1.26293 0.0934057 0.0563321 -0.496491 -0.820419 -0.5811 4.06869 5.5115 9.40848 -2.07502 5.35993 -0.268816 7.35808 -0.500375 5.9875 5.9263 +-17.0454 0.115 -0.363543 -0.245967 0.670882 0.406485 -0.829211 0.417705 -0.315419 -0.388391 0.638869 -0.62988 0.940734 -10.412 1.3612 -10.114 1.73503 -7.50193 -0.819868 -4.45653 -11.8138 -4.07063 +-8.8934 0.178 -0.35491 0.142468 -1.01797 0.0238144 -0.898292 -0.564175 -0.235859 -0.518784 -0.433333 -0.312424 2.72912 2.22143 -9.24123 -14.7582 -6.29421 -5.00801 -6.42143 -4.28422 -1.38829 -4.23226 +15.0179 -0.030 0.805659 1.46592 1.05226 0.897045 1.09574 1.14712 1.06855 1.55306 0.861315 1.24429 -3.31217 -10.5579 -5.19966 -1.06369 1.33008 -7.07011 -2.16652 -1.01969 0.346672 -6.96863 +-12.8166 -0.058 -0.549763 -0.43143 0.0593929 0.227562 -0.0615686 -1.21698 -0.4207 -0.514973 -0.754873 -0.21645 3.4156 -5.71716 -3.83601 3.4036 -2.66397 -4.03477 -1.37185 -1.88745 0.600171 0.0985639 +-2.44357 0.159 0.787845 0.76262 0.971138 1.23919 1.16703 0.575509 0.268574 0.792845 1.0686 1.11416 7.73253 5.71533 4.91817 0.733381 5.1208 -0.15899 3.52195 3.12017 3.25772 0.967486 +-14.3944 0.153 1.13359 0.581989 1.79238 0.442768 0.68939 0.933755 1.56656 1.19727 1.00306 -0.0319301 -0.576137 -5.12867 -2.4916 -6.61455 -8.30986 -9.10554 -1.83531 -2.02231 -3.0802 -3.2588 +-7.05593 -0.041 0.251778 0.706111 0.343973 0.466249 0.53148 0.241071 0.310129 0.147978 0.435348 -0.332007 5.97198 5.11006 11.0729 -1.01809 11.4032 8.55947 5.36528 9.09408 13.765 1.94121 +-15.4139 0.161 -0.173367 0.660174 0.446121 0.73749 0.721865 0.462955 0.351729 0.923606 0.49631 0.0304974 1.10384 5.64171 5.96028 -3.42949 8.42426 -0.929383 2.71411 5.62422 6.83638 11.1372 +-16.7272 -0.103 0.864203 1.07332 0.554151 0.197159 0.357125 0.259381 0.557146 0.307214 0.804698 -0.595047 -7.85421 2.93344 7.47341 4.54969 11.9031 6.61607 10.1238 6.17469 7.13431 3.02353 +0.269752 0.163 1.61775 1.24017 1.2289 0.871632 1.2841 1.51072 1.29902 1.91371 0.854841 1.70102 -8.32601 0.413311 -5.16986 -0.083908 -9.73358 0.368827 -0.966303 2.0424 -0.610769 -3.82407 +31.1555 0.353 -0.0488258 -0.497902 -0.791857 -0.174265 0.184024 -0.393513 0.0603543 0.286763 -0.470659 -0.391893-10.0806 0.844635 -5.65236 -2.51311 -8.12094 -1.5396 -4.98279 -6.06264 -4.43844 0.670694 +13.8117 0.123 0.123882 0.193206 0.219044 -0.370573 -0.07461 -0.259825 0.172372 0.177162 0.204789 0.672296 -2.89252 1.35888 -0.792501 1.76769 -4.59139 6.40646 -3.17993 4.10836 -1.38666 -6.09828 +-12.8158 -0.030 0.0779535 -0.725304 -0.720865 -0.886081 -0.113433 -0.144504 -0.231707 -0.353449 -0.714473 -0.0643893-5.57721 -5.27447 -11.0594 0.568747 -4.21572 -1.24065 -5.16468 -4.68989 -3.10181 -1.13479 +20.5334 0.012 -0.684732 -0.260762 -0.444001 0.0303206 -0.968404 -0.882459 -0.70337 -0.422297 -0.683613 -0.3121714.25916 -5.54887 -3.07795 -10.0989 -7.55475 -4.33956 -4.64688 -5.94701 2.10191 -7.93728 +-14.304 0.119 -0.872508 -1.04645 -0.502198 -0.0518426 0.39435 -0.0829552 0.0923493 0.0181511 0.0904495 0.170628-0.300663 0.215235 1.75063 -2.98833 -1.22844 -10.4116 3.64338 -6.91551 5.24383 -0.95169 +-5.13949 0.073 -0.464203 0.148939 -0.284855 -0.32243 -0.401955 0.777859 -0.0541002 -0.434389 -0.486641 -0.168315-1.22199 3.49593 -4.53567 -5.87166 3.72149 0.728773 -5.32361 5.574 -11.6519 3.84494 +-17.5817 0.113 0.00537936 -0.228955 -0.390458 -0.490911 -0.732427 -0.254284 -0.313683 -0.94898 -0.318416 -0.71563-9.15525 -1.58947 -7.88035 -0.360851 -3.65712 -1.73699 -10.2463 -3.61573 -5.69324 -4.59219 +-29.2763 0.156 0.888215 -0.352206 0.406676 0.505462 1.38328 0.455877 0.387693 0.585607 0.246025 0.86449 1.75088 6.20601 7.72552 2.32865 3.44811 4.33539 -1.73228 5.54529 -0.777913 3.58462 +10.9307 0.103 -0.0665361 -1.12199 -0.422342 -0.729938 -0.934438 -0.826227 -1.18899 -0.918974 -1.43231 -0.9832410.131649 -7.08064 -7.64051 -5.91431 0.808785 3.60627 2.72685 -5.20105 -5.94909 -1.14898 +-5.25975 -0.114 0.136595 -0.357192 -0.220222 0.463653 -0.274418 -0.637377 -0.698655 0.271567 -0.319101 -0.0338788-4.49259 -5.85348 -0.234646 -7.14768 -5.72153 2.68258 0.108796 -2.82123 -2.46171 -4.66675 +26.6865 0.014 -0.0641004 -0.170161 -0.00912994 -0.180811 0.131547 0.0200824 -0.313806 -0.0562128 0.118112 0.03916182.34933 0.561186 -2.32318 -1.5576 -0.68808 -9.21023 -2.10836 0.890284 6.69848 -4.49406 +24.8939 0.287 0.280622 1.1692 0.865481 0.665295 0.701121 0.877145 0.945417 0.420356 0.232513 0.674384 -0.364447 0.350097 -5.66247 -0.0815933 -5.68937 -5.24978 -4.74435 -6.81311 -4.50691 -4.28791 +13.2636 0.038 0.808877 0.672169 -0.361584 0.563646 0.533857 0.498708 -0.0467221 0.99564 0.799962 0.0515139 8.53068 8.5292 -6.39054 5.66468 2.15031 9.85992 4.73944 8.34426 3.21594 -8.68785 +8.47947 0.147 -0.156203 -0.514259 -0.351065 -0.226224 -0.0332659 -0.313773 0.103688 -0.177877 -0.526539 0.08251912.33886 9.1119 6.13053 -7.73287 1.24133 6.0139 0.51946 9.36234 -3.02837 3.01642 +-16.8871 0.112 0.996344 0.908899 0.525836 0.0925067 1.07892 0.695845 0.493276 0.844974 0.263206 0.628374 -7.42178 -5.11067 -7.77382 -0.0869702 -5.40754 -5.80217 0.498532 -4.15747 0.796754 2.35678 +-2.21546 0.006 -0.59003 0.859255 0.369296 0.386176 -0.0784788 -0.139698 -0.00643046 0.0761754 -0.10933 0.592148 -9.41028 0.660935 -10.1223 2.66108 -8.63735 -1.01752 -0.85313 -1.33146 0.838969 -9.54767 +30.9542 0.054 0.655795 1.31508 0.356793 1.32841 1.29763 -0.318195 -0.131701 0.791573 0.628123 0.17915 -6.6177 -2.16119 -4.29115 0.600044 -7.72234 -5.61333 -6.72527 -3.95657 -1.96331 -1.3215 +8.17744 0.001 0.298344 0.721215 0.328452 0.671422 -0.181182 -0.169877 0.834707 0.574931 0.625127 0.97891 -3.15028 0.0652471 -2.89031 -3.00544 6.23052 -2.6764 2.96268 -3.40178 4.26779 12.0397 +4.09949 0.040 -0.00394561 0.669187 -0.853537 -0.221019 -0.753379 0.444236 0.0499003 -0.405159 -0.175163 -0.43102-2.84534 -0.427181 -1.59565 -4.48744 -3.29747 -1.31205 -2.05216 -3.61773 -5.29511 -7.15844 +-35.0868 0.277 -0.658288 -0.391099 -0.109272 -0.0576926 -0.104526 -0.196861 -0.299629 -0.532961 -0.463641 0.147526-8.84337 -2.21822 -2.15089 -2.53579 -4.42273 -0.0447683 -0.800408 -2.18099 0.138897 3.84763 +1.34707 0.316 0.0370772 -0.821899 -0.0154818 -0.376793 0.136783 -0.21381 -0.3015 -0.27405 0.449466 -0.223188 -2.533 -1.55111 -0.327394 -6.24531 -3.23524 -1.12718 2.55472 -5.68396 -4.80033 -4.784 +19.9381 0.247 -0.578385 0.0236037 -0.271608 0.102526 -0.805889 -0.502854 -0.0268178 -1.02942 0.18649 -0.173809 -1.35648 -2.47064 4.18076 2.07338 -4.63878 -3.45687 -6.03357 4.88803 -7.48398 -0.946566 +-4.61707 0.364 0.0474204 0.557714 0.151255 1.57311 0.111445 0.383201 1.05646 0.840676 0.937213 0.2174 5.34855 1.32564 7.71075 6.0009 -2.37369 5.97117 6.57349 -4.53976 3.30623 1.18053 +-8.67599 0.298 -0.0446252 0.568529 -0.76236 -0.790631 -0.0622278 -0.248839 -0.242342 0.205487 -0.237677 -0.4766430.358963 5.52609 -0.281552 6.71296 3.53089 2.10832 13.0095 6.11545 6.13791 0.489893 +-22.4175 0.016 -0.570741 -0.276673 0.276219 -0.847872 -0.394364 -0.76051 -0.38986 -0.613224 -0.145979 -0.278115 -10.3965 -4.19831 -7.08005 -3.56088 -3.9948 -3.86068 -6.83553 -10.9773 -10.662 -2.87517 +-5.899 -0.019 -0.0765682 0.133662 0.595204 0.321779 0.279283 0.253065 0.132571 0.735922 0.52508 0.842176 0.400788 3.23825 -6.68659 9.38763 3.58539 5.38581 -0.389805 12.2806 -3.25947 -1.1114 +-25.9983 0.102 0.281244 -0.217976 -0.543358 -0.194056 0.299028 0.650386 -0.202472 0.638088 -0.45981 -0.977561 2.16804 -1.61443 -1.85997 7.93884 6.73626 3.1374 6.19072 7.90007 1.33219 7.64535 +-21.533 -0.052 0.87996 0.00727786 0.878973 0.618124 0.634397 0.212456 0.320134 1.03607 0.931178 -0.610625 4.37769 5.41877 5.82758 0.0311953 3.57873 5.64681 4.25218 -0.346429 -3.20594 7.43289 +-17.2664 -0.002 0.598338 0.184218 0.6591 -0.134208 -0.00415132 0.941115 0.612221 0.753986 0.685245 0.77752 4.96347 1.54774 -6.3257 -8.32197 0.148985 1.01618 -3.26605 -0.225792 -0.369201 -0.753599 +28.0009 0.130 -0.618633 -0.184478 0.252902 -0.235826 0.104096 -0.203058 0.841919 0.863768 0.9138 -0.517941 -3.27936 -0.146589 -0.704039 -9.24752 -1.35742 -0.482345 -0.280386 4.43746 -1.33769 -3.73046 +-13.2356 0.260 0.839205 0.286694 0.965423 0.445164 0.42001 0.24305 0.505994 0.728631 -0.366267 0.250387 -6.40882 -1.90516 2.23449 -0.221533 -2.89831 2.08764 -6.42261 -3.09053 2.78171 -8.29524 +-2.95891 0.039 1.04334 0.5066 0.168797 0.579223 -0.201792 0.333436 0.526349 0.592345 0.172615 1.02436 2.21448 4.79088 -3.17459 -3.34381 -6.03525 0.14126 -2.55485 -5.88669 -6.1955 -12.3939 +6.41809 0.073 0.154777 0.116261 0.754107 0.65986 0.360604 -0.0229507 0.655417 0.459581 0.477984 -0.0361653 1.66717 -4.93631 5.52133 5.27928 1.55457 1.63611 -1.52109 4.536 -2.22271 -2.24526 +-37.1957 0.213 0.0143654 -0.431021 -0.814613 0.165756 -1.16304 -0.56404 -0.422044 0.347072 -0.0806604 -0.48839 -8.69361 0.124862 -5.65675 -2.02036 1.77373 -0.294333 -9.60687 -2.26152 3.0038 -3.28267 +-7.77403 0.103 0.153075 -0.310774 -0.0264081 -0.375709 0.0752202 -0.0344188 0.10443 -0.179839 -0.529761 -0.878 -6.96124 -2.3493 -0.675758 -1.90289 -3.22245 -7.29813 -6.41375 -0.0025756 2.95685 -4.93062 +-8.99678 0.052 0.0439071 -0.0640514 0.293581 -0.0283392 0.144274 0.213838 0.163582 0.261512 -0.0563172 0.200626 6.41297 3.08429 -0.520016 5.74126 3.35205 4.4906 2.83222 1.59577 8.47777 2.92521 +16.4388 0.243 -0.0352076 0.826865 0.473069 0.803637 0.16126 0.463211 -0.0546001 1.27727 0.790599 0.942658 11.2494 9.08373 9.81507 18.4379 8.97757 9.25048 13.3197 8.93144 11.2878 13.3601 +-22.8797 0.076 -0.999869 -0.588806 -0.6924 0.0244098 -0.469529 -0.349113 -0.740477 -0.557979 -1.04353 -0.315548 -4.14969 3.12068 -4.38907 -4.66497 -2.32836 -7.71693 0.657273 -4.22024 2.66084 -2.85526 +-13.9527 0.225 -0.613188 -0.465083 -0.861618 0.1881 -0.787081 0.561344 -0.327348 0.103915 -0.0569614 0.115166 -1.08757 2.30855 -5.67553 -13.8545 -4.72915 -4.44662 -8.02952 -0.613378 -4.13741 5.01931 +-10.067 -0.096 -0.331441 -0.654741 -0.217727 -0.112737 0.129056 -0.341652 -0.764175 -0.194886 0.0699418 0.0955723-4.24144 3.05369 -3.53214 -4.88345 1.147 3.5709 -3.10068 -0.298676 -3.87959 -1.12641 +13.0059 0.055 -0.127086 -0.29143 -0.136187 0.102258 -0.484512 0.056164 -0.050604 0.530485 -0.163566 -0.155323 3.53466 5.3498 1.76326 -2.99876 6.35713 1.36435 -1.49159 2.2467 2.01109 8.26509 +-9.40065 0.225 -0.0726808 0.518838 0.838957 0.978083 0.0718526 0.382267 0.394219 -0.230048 -0.375244 0.807918 3.07935 -5.32508 10.6129 5.03295 4.67795 6.29115 4.22932 1.2225 5.23522 7.88614 +-18.9893 -0.059 -0.295453 -0.499633 -0.207579 -0.0707274 -0.32488 -0.627585 -0.14029 -0.147371 -0.477348 -0.771245-3.38881 -7.81907 -5.76349 -8.2655 -3.58174 -0.527648 -3.87224 -5.59108 -2.74243 -7.55513 +-1.98392 -0.055 -0.229926 -0.894812 -0.686651 -0.588957 -1.37825 0.191383 -0.892958 -0.212012 -0.372673 -0.229988-0.0737525 -0.577283 1.36339 -5.99242 1.12905 4.28861 -4.18338 -3.96584 -3.02429 -2.25378 +-14.2347 -0.097 1.047 1.23929 0.804095 0.756716 1.54808 0.901921 0.94771 0.852882 1.3259 1.14646 -8.629 -4.00301 -7.28975 -4.23642 -2.07029 3.17819 -7.3062 -2.25611 5.48093 -0.350042 +-36.1934 -0.103 0.569794 0.939928 0.451563 0.513379 -0.263847 -0.312419 0.971224 -0.0401409 0.108405 0.436079 7.91327 -3.25079 3.96589 11.3685 7.30773 5.88003 1.65211 -0.25277 1.02879 3.40133 +-10.2426 -0.087 -0.118973 -0.414533 -0.000976932 0.66736 0.00918165 0.116331 -0.0174417 -0.0858963 0.386812 0.271846-11.8594 -8.37333 1.23615 -8.13317 -7.42828 -3.0104 -1.48152 -2.35301 1.95402 4.04039 +-12.6107 0.085 0.129042 0.0713986 -0.883327 0.658495 -0.436272 -0.272393 0.246291 -0.276967 -0.359331 -0.272491 -2.06963 -1.83847 -6.35978 -4.85249 -4.9668 -4.11717 -0.488245 -1.94896 -7.71106 2.57003 +1.5144 -0.008 0.367336 -0.15875 -0.00290868 0.0834155 0.185442 -0.728714 -0.290221 0.0911821 -0.214749 -0.3222646.17172 10.3075 5.89408 6.09072 10.3253 7.28663 9.47745 14.6683 8.59683 8.69811 +-9.46324 0.242 0.942719 0.39156 0.963062 0.423263 0.358747 0.273203 0.305836 0.497415 0.354801 -0.107355 -7.73411 -5.70645 -3.72234 0.634408 -5.23504 -4.51611 -11.0162 -1.98375 -1.51393 -6.468 +-14.8017 0.015 -0.142409 -0.42389 -0.0122811 0.171348 -0.804908 0.0107697 -0.137683 -0.777335 -0.0347245 0.609586-0.252498 0.697231 0.5874 8.41398 3.5158 3.98601 11.5475 6.10832 -2.05667 0.43108 +0.388726 0.046 -0.147103 0.326564 0.0432097 0.568291 0.15512 0.568683 0.599994 0.808476 0.711854 0.417087 -0.510899 -2.5628 -5.31363 5.99721 -3.28906 -1.17914 1.39487 1.60839 -1.63442 -2.16402 +1.33212 -0.089 -1.20321 -1.83702 -0.229478 -0.172364 -0.8094 -1.14486 0.337295 -0.518913 -0.906588 -0.320048 2.02612 -2.66527 3.07925 -1.90578 2.56655 2.32012 -3.89241 3.93205 -6.06312 -3.32227 +-23.8279 -0.138 0.292809 0.267471 0.0707136 0.612295 0.781141 0.875721 0.183918 0.69329 0.216929 -0.0295165 4.86725 9.84952 9.56339 8.55742 1.47463 -2.12812 2.90599 3.98668 9.51594 5.86411 +3.40475 -0.077 0.882834 0.620858 0.433663 0.396507 0.158177 0.420389 0.936553 1.01429 2.00812 0.900128 -1.55433 3.81922 -2.15786 7.59464 8.51892 4.39483 10.1531 2.10355 3.44527 -0.971946 +-8.94956 -0.089 0.135163 -0.724528 -0.38065 -0.243266 -0.00740434 -1.37965 -0.319585 -0.387689 0.806331 -0.388872-8.9916 2.15567 -2.5145 -3.83202 -3.68393 -11.567 -4.09259 -8.74699 -4.19823 -8.33701 +5.64462 0.015 0.656615 0.614317 -0.161476 1.27008 0.500695 0.276966 0.691484 0.392055 0.266756 1.19649 -3.84307 -2.13301 1.52286 -3.06526 -3.9448 -10.3643 -4.95447 -7.68764 -3.3428 -11.4785 +-8.89898 -0.037 0.0542542 -0.0471349 -1.2668 -0.18109 0.483183 -0.554745 -0.351115 -0.315358 -0.0910021 0.425946 0.95686 -1.53716 -5.46212 -8.98068 -10.6882 -3.16154 -3.40805 1.20665 -9.24453 -3.77174 +-23.5283 0.114 -0.804168 -0.425456 -0.704423 -0.950608 -0.054569 0.50411 -0.361585 -1.01312 -0.81739 -0.67519 -7.42345 0.0897675 -5.12613 -1.89238 -1.19051 -6.13628 -7.42052 -8.31161 5.27063 -6.21102 +11.1699 0.092 -0.378775 -0.429358 -0.0620525 -0.449058 -0.128576 -0.0591171 -0.24868 0.302911 -0.610322 -0.393425-1.0555 -1.41913 -5.15442 -11.2665 -5.19372 -3.48252 -3.20989 -1.81928 3.16492 -3.14823 +-17.1874 0.079 -0.269145 0.0363045 0.0711968 -0.53172 -0.235373 -0.460702 -0.17163 -0.134528 -0.94903 -0.34426 2.00747 0.41237 1.54894 4.81113 9.94933 3.69077 9.58206 6.05538 7.92646 -0.282144 +-10.0696 -0.001 -0.328314 -0.389363 -0.484678 -0.0877779 0.216411 0.264544 -0.701644 -0.221491 -0.600446 -0.60460514.6878 9.24708 11.5441 9.16808 15.4518 6.62609 16.2607 7.92103 13.0471 5.43548 +3.28864 0.141 -0.348133 0.0557292 0.45358 -0.304914 -0.606091 -0.193399 -0.0723848 -0.292797 0.143399 0.168082 10.7524 9.5007 10.6095 10.2608 9.41812 13.7753 14.8907 12.2593 18.4504 16.3641 +-16.6993 0.152 -0.255016 0.254398 -0.217698 0.00941448 -0.516727 -0.0619622 -0.0486261 -0.256355 -0.258361 -0.357166-3.22161 11.6154 9.4939 3.93726 0.0509804 8.5095 -2.28272 -0.0884444 1.66275 0.54232 +4.67285 0.046 0.533945 0.749563 1.0221 0.95381 0.567329 0.131982 0.390526 0.408401 0.976763 0.258933 -10.24 2.42299 -4.33419 -5.0778 -4.36629 2.70949 3.48656 -5.57498 2.08919 -3.11959 +-10.1281 0.090 -0.13577 -0.716688 -0.254466 0.0343211 0.226257 0.184822 -0.224998 -0.0385184 0.36615 0.268067 0.872032 5.88298 2.8482 0.702253 -3.64473 -0.972251 3.80695 8.77763 -1.98902 -2.23224 +7.74676 0.291 0.530991 -0.245867 0.038624 0.184003 0.59739 1.15598 0.523922 0.566435 0.408422 0.947948 5.41593 9.11206 -1.18635 3.09562 8.56277 5.49006 2.92353 -0.918281 10.1283 -2.78442 +-5.4818 -0.100 0.446678 0.254499 0.329058 -0.174745 0.168859 -0.527854 0.111584 -0.486478 -0.180137 -0.414067 -8.58942 -0.837128 -5.81055 0.46001 1.78831 -3.75448 0.074151 0.946268 -2.77753 -6.87725 +-19.0453 -0.074 -0.0801977 -0.139321 -0.1854 -0.0807811 -0.607475 -0.147954 -0.06869 -0.193185 -0.513092 -0.77234-3.37279 -1.45155 -6.00009 -5.11618 -5.78737 -3.75389 -3.75254 -2.4125 -1.57163 -2.12838 +-28.9577 0.001 -0.852335 0.0402576 0.0805324 0.182086 0.435988 -0.125656 0.149848 0.245466 0.201264 0.119599 -6.84357 -2.60038 -4.33682 -3.91569 -4.29165 0.523075 4.40316 -7.67049 4.19253 -5.70804 +20.8188 0.199 -1.2791 -0.35773 -0.122458 -0.599585 -1.04745 -0.462272 -0.819084 -0.270226 0.0970358 -0.627328 6.12652 8.27422 10.6513 5.74973 8.84868 -1.46096 7.80016 2.55185 -0.972984 7.07664 +4.31802 -0.007 0.212952 -0.190428 -0.0870122 -0.344581 -0.103816 -0.302229 0.493031 -0.753957 -0.527468 -0.438529-11.8439 -3.27308 -7.88772 -1.50798 -9.48432 -2.06198 0.0152391 -0.886435 -7.75035 -7.40771 +-0.505043 0.028 -0.230718 -1.11162 -1.43641 -0.587527 -0.255361 -0.392885 -0.599113 -0.0628489 -0.339065 -0.007993682.68536 -0.914347 -2.56159 0.213948 -1.62406 4.11544 -5.65455 7.47536 -7.35707 1.89275 +21.483 0.210 -0.59049 0.098947 -0.359193 -0.907268 0.0658698 -0.18414 -0.754193 0.0155255 0.166336 0.150102 1.98114 2.94289 6.69642 5.88215 9.30353 1.87567 8.94958 6.0297 -1.81797 0.987269 +-0.87239 -0.030 -0.281624 -0.459188 -0.807875 0.0198372 0.27404 -0.355544 0.0533703 -0.199483 0.0593961 -0.5729770.871815 -3.42539 3.24971 -0.944338 -1.03114 1.03683 -11.0294 -0.00419819 -1.3825 -1.27066 +-11.2647 -0.021 0.260918 0.65508 1.14519 0.764624 -0.129089 0.718472 0.486595 0.881431 0.544791 0.596287 -2.17759 -6.19048 0.168158 1.79744 -7.07928 -4.23214 -3.99698 1.30578 -2.13689 0.562933 +8.11522 -0.087 0.0119464 -0.697412 0.236311 -0.0688223 -0.636378 -0.726477 -0.720397 0.00976167 -0.39211 -0.338141-5.56344 -7.04831 -5.56118 -0.946524 -8.30506 -6.5824 -7.52384 -1.27145 2.69439 -5.47501 +13.1425 -0.071 0.0437279 -0.193517 -0.406152 0.173931 -0.502388 0.579006 0.959478 -0.060509 0.95241 0.996073 -5.04319 -5.73793 -2.31249 -0.665039 -7.96891 -9.43525 -4.12188 -11.5631 1.8075 -2.4433 +-25.4189 0.086 -0.701281 -0.190647 -0.779243 -0.862536 -0.483534 -0.284065 -1.13669 -0.638287 -0.758644 -1.1445 13.4058 13.3327 15.5273 8.65449 15.7607 8.73894 6.41287 9.44487 13.3751 8.09725 +13.6722 -0.002 0.219902 0.464365 0.261343 0.107246 0.456479 0.0720051 0.601505 -0.0948435 -0.153911 0.874291 -8.09645 -2.71422 -3.52294 -3.18052 0.297642 -0.306479 -3.88487 -6.3524 -2.71023 -5.94495 +-12.706 0.265 0.353271 0.0279151 0.17697 -0.120799 -0.0853277 0.385593 0.829855 0.12526 0.31101 0.76436 4.3874 7.65826 -2.12718 10.3093 4.28545 2.34127 5.21405 -3.22899 8.28304 6.10733 +-38.2827 0.076 -0.370568 -0.175461 -0.477961 -0.204034 -0.89386 -0.0769797 -0.126445 -0.743023 -0.411342 -0.03554-0.282748 0.996179 -1.80202 -5.60016 -3.81463 -2.08237 -2.15237 -7.61847 -5.14175 1.8683 +-4.35922 0.168 -0.346131 -0.00331255 -0.0458365 -0.770171 -0.135057 0.519904 -0.1053 -0.191283 -0.517141 -0.7320047.25357 -3.94092 6.06856 2.46537 4.89057 6.28299 3.47098 4.74502 4.57788 2.79379 +-8.5878 0.079 -0.116174 0.319744 0.058724 0.203287 0.0472211 0.533262 -0.47532 0.514249 0.332698 -0.174861 2.70376 8.79115 9.79146 3.63676 0.40322 -1.42663 -1.7733 7.19719 6.13028 5.26482 +0.00126554 0.036 0.471154 -0.561529 0.963543 0.70371 -0.181825 -0.507578 0.760446 0.108328 0.192296 1.46981 -7.20872 -1.99976 -5.59991 -7.17227 -12.9922 1.24055 -0.0862698 -0.0615605 -2.17436 -4.64993 +-35.1385 0.177 -0.262845 -0.429495 -0.269869 0.275804 -0.103183 -0.438652 -0.79523 -0.824595 -0.103479 -0.28458 -4.04412 -2.57497 -1.22463 -12.8857 -0.0660884 -1.2277 -7.84685 -2.79714 0.55646 -5.94922 +-1.44662 0.113 -0.506302 -0.238653 -0.274073 -0.71673 -0.457384 -0.662817 -0.580842 -0.374496 -0.782228 -0.110292-1.99105 -9.15757 -2.49749 0.288862 -5.86532 -1.14294 -1.48481 -3.06778 -6.85456 -3.21277 +-4.85137 -0.037 0.278387 0.698031 0.5689 0.42673 -0.0448701 0.426568 0.164576 0.528311 0.257849 0.381893 5.19466 -4.93215 -1.5434 -3.17905 -8.35715 2.38744 0.707914 -4.85725 -1.63091 -6.87735 +-12.0724 0.110 -0.653922 -0.485792 -0.0907819 -0.847098 -0.721142 -0.865211 -0.859468 -0.505357 0.19787 -0.012136-2.79538 -4.97342 -7.52783 -2.85046 2.38323 4.5245 0.454033 -13.2346 -6.35607 -5.37893 +5.43025 -0.002 -0.408945 -0.24887 -0.726281 -0.799536 -0.303338 0.672134 0.432962 0.0442305 0.162054 -1.12446 4.64577 5.68761 2.37221 2.72045 -0.361625 -0.043308 6.29371 10.6783 -2.08146 -4.81543 +-10.9269 0.010 0.707035 0.753734 1.27914 1.37221 1.17343 1.03068 0.462895 1.04359 0.940644 0.790358 -1.14101 -3.09295 -2.83417 -4.14487 -7.42814 -0.196093 2.72627 -0.720959 0.557183 -3.76873 +13.4973 -0.020 -0.699088 -0.450523 -0.377976 -0.252618 -0.210446 0.346335 0.184986 0.176918 -0.57267 -0.366514 7.43115 6.08136 2.8722 8.0034 -0.119397 2.55406 10.4049 0.982156 2.76269 2.48385 +12.9258 0.182 0.829875 -1.02258 0.396793 0.79934 -0.0872027 0.441593 -0.0915072 0.349292 0.512609 0.0234154 -3.80604 1.91239 -9.89168 -0.978416 -2.08951 -8.43803 -0.88984 -3.47384 -7.03131 -1.81382 +8.72933 0.068 0.211425 0.369977 0.0914842 0.263407 0.323529 0.825505 0.288047 0.0408296 0.181387 1.03588 4.95468 6.39961 -1.81614 7.55529 6.46376 -0.355482 2.44933 3.86081 7.7402 3.89494 +11.834 -0.073 0.149245 -0.494247 0.139358 0.336097 0.23973 0.6597 -0.218233 0.155717 -0.443581 -0.143586 1.50845 2.74256 -0.523428 -4.62708 -0.455869 -2.4305 1.24597 5.40807 -2.76498 4.85735 +17.2052 0.177 -0.296744 0.523916 -0.326819 0.199914 -0.386316 0.455684 0.26575 -0.685089 -0.298594 -0.468961 -2.93388 8.16429 0.383536 6.18612 5.87961 10.6385 10.2001 -3.45145 2.4304 7.91783 +-15.8037 -0.088 0.3585 -0.38916 -0.313414 -0.339497 0.205898 -1.2978 0.0128905 0.140848 -0.173724 0.242962 10.2957 8.02193 1.53639 8.24269 4.61699 3.90052 5.8074 5.7707 8.40837 1.58828 +-8.58294 0.003 -0.140883 0.229543 0.0391015 -0.306221 0.448854 0.0296677 0.559546 0.217101 -0.0270272 -0.0623563-0.0104735 -4.28407 -4.6669 3.10475 -7.95328 -1.49414 -7.05122 -1.64051 -3.87253 -2.48045 +45.944 0.183 -0.00216608 0.363706 -0.0842212 0.746122 -0.629198 -0.358531 0.345403 0.218541 0.736954 0.475365 4.18193 4.60717 4.87473 2.36117 3.919 0.89344 12.162 -2.82882 1.27442 -4.88279 +-28.9124 0.079 -0.376896 -0.429959 -0.155454 -0.297174 -0.566224 -0.566926 -0.35113 0.0487534 -0.413896 -0.2725931.67421 -1.55867 -1.22007 -3.14636 -1.74674 3.23786 -5.044 1.61257 -6.16414 -7.4302 +-7.36535 -0.033 -0.581341 -0.147789 0.0974891 -0.487866 -0.207327 -0.528012 -0.446577 0.0270824 -0.298704 -0.00645742.44398 0.798349 -13.1283 -6.41761 -2.69188 -3.97821 -1.78322 -6.64565 -0.899019 2.57231 +22.0978 -0.001 -0.12865 0.0250176 0.259715 0.111516 0.303006 0.321408 0.392188 0.437651 0.654412 0.430084 14.0965 12.1259 13.0232 6.785 14.7478 7.98373 9.06003 6.43588 18.5429 8.4728 +15.3428 0.251 1.01364 0.876761 0.497021 0.384296 0.952084 0.797899 0.914643 0.827238 0.675075 0.0905408 -3.46156 -0.0418897 -7.25367 2.31508 0.068109 1.96882 -2.24285 -6.28377 -5.64959 -1.13239 +-19.8676 0.004 -0.375678 -0.153132 -0.211457 -0.594869 -0.254909 -0.056291 0.274088 -0.319004 0.155349 -0.563468-6.79733 -7.77606 -5.028 -6.98794 -1.91633 -2.82773 -3.15097 -4.10836 -1.59286 -12.7854 +17.7566 0.220 1.25344 1.17832 1.15591 0.190388 0.248347 0.408778 0.332872 0.677119 0.565934 0.0572545 5.30276 1.6278 10.9316 2.09086 9.68403 8.42256 7.59231 4.25297 5.31737 4.82302 +3.37993 0.289 -0.575777 -0.077353 -0.269862 0.581695 -0.894338 -0.0794926 0.611198 0.19658 -0.285143 -0.281303 -0.628927 14.5931 -1.67582 6.16045 5.5293 8.99124 7.36412 3.15845 4.30143 5.14995 +10.1268 0.118 -0.809376 -0.537111 -0.184789 -0.315861 -0.1047 0.440045 -0.806663 -0.173328 -0.591339 -1.06344 -4.33202 -5.12697 1.19222 2.57595 -5.15937 -2.72714 -4.56317 -5.60015 -8.05985 -4.7622 +33.5835 0.088 -0.214747 -1.0483 -0.694988 -0.210271 -0.279252 -0.530068 -0.132592 -0.111091 -0.535112 -0.642925-4.54355 -0.34931 3.50053 1.62437 -5.3034 -4.02914 -0.627085 -9.61991 -9.14268 -9.00993 +-24.8332 0.030 -0.209901 0.36379 -0.100743 -0.870622 -0.773068 0.167635 -0.771431 -0.692083 0.324268 -0.458064 -4.03126 6.38702 -3.31938 2.93201 -5.54726 0.611194 -5.90333 1.32932 -8.28937 -5.53514 +2.77188 0.058 -1.1561 -0.97105 -0.979739 -0.5574 -0.431993 -0.785002 -0.791664 -0.0956261 -0.119296 -0.660286 0.343644 5.89501 9.42028 11.4543 -0.546369 -3.65916 0.954172 4.67653 3.91234 -2.86618 +-10.4234 0.243 -0.247667 0.0507124 -0.755145 0.112765 -0.289682 0.0520777 0.112382 -0.196927 -1.08746 -0.198623 -0.690918 -5.3728 -3.93811 -6.30576 -9.89838 2.52015 -10.0095 -11.4664 -7.17306 -0.813105 +-35.8734 0.023 0.478547 1.35019 1.13375 1.08933 0.942922 0.742926 0.816399 1.54377 1.77407 0.211471 -6.56534 -9.16025 -4.79654 -7.84282 -6.65781 -10.5052 -8.34299 -0.879041 0.656271 -8.05545 +-17.8944 -0.053 -0.475077 -0.060225 0.123898 0.447927 -0.347727 -0.352231 0.0142687 -0.510832 -0.383981 -0.82076 5.71312 0.754826 4.05665 -1.42233 6.9618 -4.31943 0.0388308 5.92739 5.7988 -3.19829 +-10.9551 -0.025 0.571031 0.508859 1.61316 0.701615 0.622184 0.879668 0.178255 1.28497 0.994613 1.32162 -2.7309 -3.53095 -3.91357 1.6498 3.02442 -7.9567 -0.312139 -2.77741 -15.516 -4.47072 +2.18893 -0.031 0.780797 1.36222 0.626679 0.79725 1.22559 0.805532 -0.0497054 0.367947 0.130836 0.983643 3.65554 -3.16359 3.39973 6.85214 7.8482 7.83479 5.51922 3.82401 -0.327466 1.4253 +6.61102 0.105 0.212882 -0.508623 -0.302935 0.511013 0.260377 -0.309607 -0.312006 -0.286309 -0.266231 -0.312452 3.40848 -7.21672 1.76836 -6.25175 -9.03564 -2.45454 -5.38853 2.80797 -4.39191 2.29427 +5.02737 -0.011 -0.388791 0.186315 -0.946038 -0.0322526 -0.9271 -0.291327 0.0845617 -0.463842 0.00334752 -1.0216 4.24132 2.79138 17.9463 15.2281 3.64884 12.2009 7.86721 5.19873 4.7153 10.8356 +-6.5837 -0.072 -0.572095 -0.0666552 -0.0502213 -0.0892812 -0.928651 -0.427966 0.0222998 0.566721 0.350818 0.351634-5.44953 3.02332 -13.6953 -1.4639 -3.61063 -10.974 -6.08053 2.21919 -7.43092 0.747531 +24.7153 0.122 -0.0824042 -1.11783 -0.0393226 -0.328032 -0.619012 -0.517363 -0.549103 -0.776345 -0.234694 -0.50768-4.76541 -8.51103 -1.86056 -5.08034 3.18031 -3.5121 -3.73266 -3.55658 -1.09516 -1.52472 +-3.79656 0.098 0.776987 0.673302 0.0549676 0.15631 0.829286 0.310867 0.708224 0.76628 -0.0650464 0.598744 10.8707 5.40135 6.83939 5.88072 3.87178 2.95479 7.16912 -0.520687 10.2358 7.23258 +-25.5208 0.056 1.50301 0.0634388 0.718581 1.43374 0.847815 1.19778 1.06528 1.3538 0.455344 0.977204 -3.58279 1.05078 -0.61303 -9.16156 -1.93345 -1.8427 -7.26239 1.54715 -13.1852 -5.55239 +-4.05678 0.104 -0.669913 0.150316 -0.456431 -0.048853 -0.460859 0.20477 -0.313043 -0.11363 -0.201804 -0.18983 -3.4333 -2.81479 -6.025 0.497591 -2.2679 2.25694 -4.63356 -5.95153 -3.83956 -3.41783 +23.9873 0.058 -0.548105 -0.612709 0.612415 0.693414 0.0636869 0.468479 0.35283 -0.0911077 -0.127459 0.17459 8.16368 4.35708 4.25271 0.562772 8.18829 6.87546 7.93667 4.86182 10.7242 4.91557 +28.2244 0.056 -0.413587 -0.234309 -0.220334 0.461918 -0.286328 -0.329397 0.326892 0.113913 -0.449927 0.229752 -9.05016 -6.43485 -4.12211 -0.668528 3.41143 -3.63657 -5.65758 -7.88399 -1.69546 -5.90955 +17.1883 -0.024 0.188067 -0.311474 -0.728028 0.286746 -0.49993 -0.0110862 -0.429689 0.101928 -0.861709 -0.450524 1.21095 -2.58026 1.12633 -4.06067 -9.79559 -10.4786 -0.0706213 -7.67741 0.354962 -6.85779 +8.63974 0.054 0.129061 0.0508843 0.130176 -0.323231 -0.185302 -1.24989 -0.0665781 -0.247501 -0.225778 -0.3654870.636473 6.21419 4.81886 3.0275 7.3985 13.6043 3.97369 2.38206 6.08141 -0.0056077 +2.12121 0.048 0.101365 -0.458815 -0.579058 -0.312161 -0.156374 -0.0409699 -0.763141 -0.806659 -0.186721 -0.4977771.24218 -0.550043 2.67526 -0.577709 -2.49642 -5.93384 -2.43986 0.244505 -2.14078 -7.2026 +4.46539 0.180 0.605788 0.484101 -0.475779 0.151971 0.342829 0.525189 -0.0673274 0.810378 -0.0508678 0.411106 -2.41651 -5.3746 -5.0333 -4.34748 -8.54796 -5.37907 -4.03268 -6.87899 -2.40088 -5.88814 +23.7286 0.134 0.403729 0.263917 0.452142 0.304877 0.2973 0.231837 0.0970275 0.537128 0.285996 0.431751 -1.63918 0.293584 -1.49935 -2.6119 -0.47735 0.482144 4.38982 1.70593 -9.897 -2.46056 +1.58089 0.004 -0.274659 0.215371 -1.157 0.157423 0.968165 -0.41266 0.0874983 -0.0813469 -0.472291 0.198898 13.6296 1.07058 7.79458 12.7306 17.3077 13.5738 3.3364 18.7624 10.0463 15.8773 +7.42613 0.119 -0.456967 -0.862781 -0.233382 0.235946 -0.203196 -0.445861 -0.122899 -0.354324 -0.286387 -0.330441.36995 -7.06909 2.56032 -2.02647 -9.3929 -3.79788 1.33762 -3.98826 -13.7441 -3.90774 +1.66714 -0.005 0.405621 -0.496984 0.00220369 -0.593903 -0.27895 -0.731406 -0.844167 -0.377484 -0.166731 0.1748651.70225 4.96592 -8.42187 -7.3401 -2.78536 -0.645447 -3.79002 -3.40403 -3.73809 -1.09941 +-3.19542 -0.078 -0.201578 0.120937 -0.670163 -0.977426 -0.00167142 0.0336994 -0.134624 0.037578 -0.634885 0.3686973.82638 5.42669 4.48663 9.36027 9.95647 -0.5815 0.451518 0.0279553 5.29785 8.53146 +28.4669 0.073 0.626348 0.330777 0.193053 1.18472 0.0391593 1.06372 0.168424 0.976522 -0.0309279 1.00043 2.34252 6.46843 1.14031 1.14285 6.75523 4.66473 5.69588 -2.35238 7.39749 7.92705 +-8.57161 -0.105 0.181854 0.869736 0.290356 0.106624 0.110109 0.270335 0.0965281 0.626991 0.101933 -0.453282 3.64532 2.41136 5.97944 -4.30494 2.91692 0.8861 8.13891 0.253786 4.7233 7.79304 +16.9446 0.264 -0.672029 -0.256276 -0.484127 -0.832853 0.0872576 -0.207347 -1.04533 -0.366915 -0.582746 -0.8231441.74488 6.1769 -3.31401 5.67113 4.71553 4.46622 7.032 -8.24266 11.0342 9.99963 +-12.1708 -0.104 -0.886345 0.0567716 -0.36836 -0.553539 0.0753253 -0.0711467 0.0404946 0.470616 -0.666298 -0.8129953.34457 0.822496 -9.466 -1.38291 1.93453 -0.8059 -6.12202 -8.40591 1.0078 -7.79482 +0.307852 0.039 -0.56357 -0.388749 -0.29737 -0.916255 -0.399329 -0.649158 -0.399653 -0.356491 -0.963776 -0.6297714.59717 5.08817 2.68375 4.01991 0.245798 -0.415604 9.1888 -1.4758 -1.73744 4.55027 +-28.7285 0.005 -0.538781 0.710169 -0.306228 0.80171 1.06208 0.269524 0.416608 0.594621 -0.17962 0.824704 -5.7366 -5.15025 -0.274005 0.589047 2.3798 -6.57429 -3.87204 -6.49518 -3.71906 -7.78095 +-7.65243 0.311 0.222608 0.554644 0.0860363 0.366854 0.287878 1.03139 0.28728 0.925488 0.869517 -0.0480204 4.66179 5.32508 1.25119 -4.51219 6.17142 8.26336 -3.58665 0.495214 7.77906 2.70571 +3.3677 0.132 0.624163 -0.0610468 -0.159232 -0.630985 0.223133 -0.353665 -1.12118 -0.619674 0.0863221 -0.06852184.21715 5.97451 10.8432 6.08713 3.95525 7.54832 0.452008 8.75443 -0.75081 -2.78276 +17.8943 0.196 0.270166 -0.234349 -0.694542 -0.595859 -0.489635 -0.209669 0.433391 -0.634694 -0.940519 -0.174792-2.96934 -0.00309933 -0.980774 -5.12118 -5.16977 -2.40073 -7.79039 -10.5799 -6.73608 0.888141 +-12.0925 0.160 0.702002 0.191271 0.0916295 0.786051 -0.134288 0.217221 0.603096 0.863264 0.239349 0.353578 3.59146 4.82282 1.0557 4.73723 2.42302 7.66698 1.9958 -0.475813 0.608694 10.2937 +3.58807 0.192 0.0267553 0.420924 0.827792 -0.263052 -0.349415 0.0832848 0.109285 -0.380902 0.0917224 0.433097 -4.4932 1.47337 -1.50093 1.97585 3.85772 2.16275 5.93773 1.14336 8.91903 7.0289 +12.1303 -0.008 -0.683981 0.0267926 -0.577288 -0.400952 -0.15683 0.203298 -0.31119 0.0957711 0.114087 -0.772197 10.5624 -2.15652 6.30379 4.8495 -3.74351 -2.92362 5.19917 5.32761 1.94084 11.7004 +-30.0697 0.083 0.618853 0.199159 0.311692 0.855967 0.0889848 -0.0054098 0.690754 0.596274 1.29606 0.675269 2.58632 2.26196 14.7309 -5.65038 -0.0680443 8.54755 4.50285 2.33241 -6.81878 -4.69975 +44.7718 0.061 -1.31474 -0.260877 -0.243179 -0.723749 -1.14357 -0.513215 -1.22279 -0.290651 -1.31956 -0.60688 -4.29935 -0.65649 8.05178 -1.59753 -5.77877 -1.9412 -3.00087 -3.80083 1.60165 -2.92827 +33.065 0.120 -0.331781 -0.29115 -0.29319 -0.103905 0.0544057 -0.612546 -0.591508 -0.389274 -0.0752908 -0.27363-2.00808 9.26829 7.1581 1.14681 4.59723 9.82575 -4.85502 1.25352 2.48235 11.1246 +8.31989 0.098 -0.252724 0.0444735 -0.270164 -0.0188467 -0.434916 0.382726 -0.653605 -0.411573 -0.0540899 -0.253941-9.51375 -2.50328 -3.37282 -0.814751 -2.53708 3.90199 -4.36699 -7.05402 2.61776 -2.67641 +24.1279 0.239 -0.209097 -0.137169 -0.185252 0.295852 0.0430447 -0.281626 0.0968095 -0.217855 0.501163 -0.0426599-1.89306 -8.07098 -1.25231 4.6795 -7.42377 -4.45798 1.11447 2.66983 -3.11329 -1.85979 +2.88818 0.187 0.0239697 -0.581266 -0.177952 -0.0781048 -0.92268 -0.992609 -0.261976 -0.534548 0.0261573 0.07932583.10885 -10.9265 -2.88703 -2.65598 -1.89084 -9.29552 4.0889 -5.37831 1.71851 -3.08695 +-10.7979 -0.067 -0.58315 -0.494456 -0.737397 -0.384416 -0.0546767 -0.63889 -0.524139 -0.805276 -0.67731 -0.422014-0.531534 -6.96004 -4.12257 -5.23722 4.91851 -1.1868 -6.47975 -5.00777 -5.81979 0.214825 +6.88389 0.007 0.272346 -0.473883 -0.224084 0.323026 0.733429 -0.159265 0.374354 -0.0999866 -1.21977 -0.126179 9.3958 16.3393 11.6484 13.4547 8.40509 10.227 11.2548 14.462 6.75458 11.9896 +3.80739 -0.002 -0.295278 -0.56488 -0.0147243 -0.181241 -0.683888 0.322402 0.11778 0.442987 -0.812775 -0.231178 2.8697 -6.04617 -3.30611 -5.81237 5.06158 5.55315 -2.52209 -8.06648 0.495757 1.7842 +4.73484 -0.083 -0.236496 0.213359 -0.115977 -0.0880057 0.072983 -0.220307 -0.440633 -0.588201 -0.219656 -0.0308364-0.690778 -9.57208 -5.87473 -3.14179 -6.6049 -3.79021 0.132689 -3.62394 -6.57172 -5.23751 +-6.67321 0.079 0.260375 1.1067 -0.374782 0.475439 0.884105 0.757297 0.221996 0.424347 0.00623523 0.403642 16.9791 6.95976 16.5204 12.2595 10.7414 12.3762 6.78175 11.4033 2.92772 11.4956 +20.1407 0.050 -0.164927 0.11279 -1.20953 -0.26393 -0.311291 0.160603 -0.0479281 -0.44448 0.269225 -0.848843 4.84813 0.952994 -5.89196 1.4693 -3.41969 -3.52646 -3.83936 -4.45898 -4.30712 0.557919 +9.96544 0.164 -0.379081 -0.243536 0.58347 -0.152722 -0.195193 0.257968 0.247233 -0.439817 0.00200246 0.093431 8.62817 3.56557 -0.462728 4.25571 6.40151 -1.20668 0.319365 3.36398 5.89227 7.2971 +22.5615 0.201 -0.635456 0.15002 -0.429572 0.076717 -0.148176 0.206691 0.620508 -0.137733 -0.694846 0.172951 -3.65639 -7.8438 -1.32837 -4.88266 -2.77755 -1.32818 -0.501993 -9.45987 -6.61967 -3.1558 +-22.3861 0.188 1.59091 1.29847 1.09654 0.620097 1.11695 1.05153 1.04917 1.50283 0.348509 1.11005 -8.17091 -6.58624 -4.93256 -1.82569 -10.8011 0.838708 -7.85925 -4.58272 -3.53936 -8.63138 +-29.8371 -0.035 0.20939 0.0665416 -0.191786 -0.689055 0.160133 0.377956 -0.487108 -0.519516 -0.540235 0.483431 3.44096 1.95263 1.69602 -5.79521 7.86018 0.330953 -1.19638 2.02484 -8.81587 3.59433 +-9.5008 0.285 -1.23435 -0.256076 0.501136 -0.258802 -0.755185 0.0658286 -0.561 -0.257282 0.0254806 -0.146939 5.31091 -2.9298 9.06588 0.857526 -4.57502 -2.06175 1.18953 -2.36263 -1.2883 -2.66102 +20.2182 0.203 0.20232 0.816658 -0.416612 0.19232 0.832775 0.15355 0.215211 1.03201 0.637306 0.343398 -4.07936 2.94537 -6.55825 -1.10679 -13.5302 2.87923 -1.27413 -1.62871 1.64446 -4.52948 +16.1263 0.034 -0.0199367 0.222113 -0.213212 -0.08871 -0.441961 -0.552814 -0.124084 0.342414 -0.294101 0.316911 -1.05567 -9.96191 4.18737 -0.712293 -2.8657 -6.99955 -3.38194 -5.06291 -1.64723 -9.15199 +-15.5543 0.095 -0.459171 -0.452036 -0.53963 -0.546317 0.0231951 -0.146653 0.2836 -0.402009 -0.348568 0.017636 13.375 5.97912 2.66088 7.00637 0.412877 12.4911 10.7606 8.81226 14.5572 21.6786 +-29.3667 0.108 -0.542198 0.195395 -0.247778 0.605677 -0.139307 -0.569301 -0.792003 -0.102092 -1.02366 -0.249644 6.49602 -4.66103 2.65952 0.374602 -2.73249 1.2121 4.71358 0.120348 -7.96334 -3.68203 +-0.154401 0.023 -0.206416 0.228438 -0.31685 0.323209 0.0858672 -0.119298 -0.108407 -0.0535913 -0.257681 -0.742596-9.84718 -11.2869 -4.02061 -0.0260506 -1.27917 -3.93998 -2.21182 -4.90772 -4.35506 3.08357 +-4.84526 0.120 -0.388582 -0.259866 -0.6759 -0.157285 0.38244 0.0720114 0.146711 0.127938 0.0898255 -0.114351 -4.5841 -3.57941 2.74127 -1.55671 -1.71185 -1.82531 -0.228586 -7.24811 1.46964 -1.18272 +14.7989 0.050 -0.535661 -0.635582 -0.401552 -0.358087 0.663301 -0.214868 0.529226 -0.679997 -0.248359 -0.309845-2.83747 -0.773576 -8.37479 -3.45341 5.22951 2.81523 -4.75226 6.69504 -4.36342 -2.54174 +2.72661 0.017 0.681869 0.687953 -0.201189 0.710984 0.598075 0.447602 -0.555942 0.697465 -0.0807225 0.556044 -13.3696 -2.20603 -2.04236 -2.80321 -6.27089 2.06521 -2.73235 -2.43437 0.910288 -8.27361 +14.869 -0.094 -0.0979387 -0.0516637 0.267311 -0.185104 0.776587 0.225333 0.319865 0.0108601 -0.00213042 -0.403092-7.60837 1.86322 -5.5249 -4.77194 0.700745 3.28919 -1.19702 -9.6968 -6.36672 -5.18311 +13.4911 0.264 0.12291 1.05354 0.851256 -0.123697 -0.234321 0.570665 -0.323034 0.29954 0.251571 0.0467584 9.35225 11.1519 4.564 -2.42366 0.486853 2.1226 11.3156 1.15323 8.31808 5.35848 +-55.9399 0.577 -1.08045 -0.184448 -0.110615 -0.638595 -0.380193 -0.688914 -0.275137 -1.44636 -1.06036 -0.407675 2.11931 -1.32392 -1.65181 -10.36 -10.927 -1.01894 -2.39061 1.22519 -6.1869 -1.95378 +25.5373 0.278 0.134064 0.68454 -0.303284 0.628766 0.596314 0.590976 0.508475 -0.0582736 0.366101 0.783123 0.126303 -2.38178 -5.51785 4.56956 -6.87736 -0.201857 -1.77387 0.284235 -3.27761 -3.88752 +29.3652 0.160 -0.583493 -0.0703749 -0.15595 0.0025861 -0.0754947 -0.558969 -0.848252 -0.898108 -0.907496 -0.9075762.77944 0.499409 2.22622 3.98552 -0.26596 7.76042 3.80473 7.92147 2.65301 6.14783 +0.023665 0.127 0.430649 -0.399339 0.533677 0.48149 0.481479 1.05459 0.407282 0.551047 -0.314157 0.678351 -10.4586 -2.61196 -0.309485 -2.63505 -7.85844 -6.66419 0.319704 -8.16396 -10.7313 -8.25806 +21.6032 0.131 0.144352 0.123244 -0.0728221 -0.126264 0.0968878 -1.1739 -0.90788 -0.635144 -0.605095 -0.73136 -5.10699 -1.9833 2.01902 1.9399 -10.0845 1.27252 3.62522 -3.94384 -3.29967 -12.774 +-47.4357 0.028 -0.227783 -0.371905 0.439869 -0.627482 -0.198952 -0.543473 -0.719513 -0.982919 -0.262148 0.5652662.88027 3.75035 5.47637 6.03795 8.66188 2.77595 1.93127 7.33049 7.48909 -0.351819 +-28.4247 0.157 0.068847 0.486505 0.340227 0.351069 -0.147017 0.437064 0.370781 0.810439 0.666057 0.364885 0.884802 4.49821 2.84946 10.1773 4.47753 0.936742 6.88108 1.4829 1.43215 1.77575 +-7.21742 0.168 0.273942 -0.337309 0.328476 -0.692411 -0.445311 0.030779 -0.0556782 0.0343883 0.206965 -0.210636 4.3144 4.96154 0.135889 11.0604 -0.885356 5.19934 5.46201 5.02716 5.75616 1.52032 +5.79671 -0.037 -0.670352 -0.236916 -0.583599 -1.38321 -1.0259 0.179569 -0.424722 0.368958 0.140256 -0.758154 0.375996 5.08785 -5.47716 -5.94486 -4.11918 -1.95516 -5.19226 -0.310243 -12.3668 -2.94726 +-23.9038 -0.019 -1.22113 -0.288069 -0.393247 -0.620422 -0.250095 -0.920659 -0.265274 -0.253354 -0.645208 -0.141576-4.65506 -5.65456 -1.94529 -3.07563 -4.25801 -1.64091 0.0852483 -1.51242 -3.59913 -6.3502 +29.3828 0.254 -0.360398 -0.218821 0.0890948 -0.930026 -0.459383 -0.142272 -1.0936 -0.358725 -0.482748 -0.155309-3.03863 -5.51439 0.840506 -14.5522 -0.00719906 -2.2348 -8.09652 -3.7172 -3.59107 -5.18399 +-7.86393 0.041 -0.141116 -0.41913 -0.254543 0.39408 -0.350777 -0.529797 -0.716359 0.648297 -0.652871 -0.527422 -4.15251 -6.21444 2.53263 0.390192 -5.33647 -0.251392 -5.06612 2.25723 -3.70504 -7.83444 +-28.2955 0.223 -0.0858266 -0.199049 0.464062 0.606767 0.0201769 0.691827 0.121639 -0.400474 0.730574 0.550991 0.043872 -4.84915 -2.71336 4.17154 2.35753 5.47521 2.64483 1.36756 -1.9918 -1.84565 +9.61703 0.271 -0.112179 -0.735313 -0.841814 -1.02292 -0.280771 -0.64356 -1.16718 -0.478939 -1.04718 -0.796602 -5.31346 -3.99706 -3.54242 -2.91224 -10.1465 0.359118 -2.42891 1.50636 -6.57244 4.23749 +31.5372 -0.117 0.683965 0.72449 1.25516 0.549531 0.944713 1.52133 0.971823 1.30831 0.89582 0.921672 4.54641 13.0033 3.07001 1.51286 5.95798 0.773439 -1.43385 6.02572 6.16347 3.01153 +3.71252 0.130 0.470331 0.469062 -0.0901958 -0.401918 -0.304933 0.0976539 -0.894529 -0.870105 -0.743641 -0.489811-5.68369 0.614496 -6.21396 1.92659 5.7892 -1.04967 4.39947 8.62708 4.90852 6.07706 +0.71823 0.161 -0.371579 0.143231 -0.269202 -0.825421 -0.0207742 -0.549555 -0.105837 -0.470565 0.598685 -0.2211515.31853 4.50815 8.22367 -2.61466 -0.3587 1.7202 12.6145 4.83406 6.01084 1.99834 +12.1638 0.300 0.515647 -0.10041 -0.255051 0.302266 -0.864648 -0.373099 -0.303417 -0.380018 -0.507045 -0.412584 2.88083 13.0819 8.7753 12.3204 10.1146 1.09848 0.754276 5.55414 10.6364 -2.26689 +-24.7269 0.265 -0.867218 -0.0388174 -0.717721 -0.301096 0.481859 0.214692 -0.758456 -1.03184 -0.560845 -0.337484-1.2721 1.05466 -1.05828 -4.17614 -0.433741 -2.84049 -2.5369 -7.28521 3.41284 -7.0456 +-2.2096 -0.002 0.202323 0.0546579 0.310294 -0.00737304 -0.394144 0.73223 0.0813854 0.0220035 -0.155771 0.119247 -1.41612 -0.96636 -3.61088 -3.35568 -2.97411 1.21773 -1.52028 -5.04095 0.366049 3.331 +7.59346 0.216 -0.683964 -0.551969 -0.348055 -0.474458 -0.129779 -0.752559 0.488495 -0.613859 0.128596 -0.136931-1.57443 1.87702 0.388564 0.281534 0.224644 -0.681423 1.72203 -6.80623 0.881859 -0.502733 +21.0724 0.064 -0.277763 -0.11006 -0.414771 -0.184136 0.464542 -0.574308 -0.0604345 -0.017963 -0.0992767 0.100744-6.51774 -1.06227 -1.56665 -12.3738 -13.5597 -5.60117 -3.50593 -1.77807 -2.66413 -4.19688 +-23.3047 0.119 -0.21926 -0.393953 -0.0430177 -1.36206 -0.40978 -0.198858 -0.762329 -0.394369 -1.10174 -0.08261797.06785 8.67892 4.47671 -1.16744 5.44223 5.59612 1.9535 4.04492 9.22852 3.75663 +-3.58243 0.297 0.390903 0.484399 0.146902 0.012603 -0.0322272 0.641274 -0.283752 -0.000280401 0.11689 0.578136 9.18418 6.6824 1.65324 1.94506 -0.734778 8.61697 8.77552 0.982551 9.83367 9.18678 +4.21558 0.051 0.335184 0.215103 -0.150667 -0.269832 0.182501 -0.636876 0.435619 -0.829691 -0.513386 0.121219 0.629753 -0.859845 3.45041 -5.55606 -3.39741 -7.62929 -2.53888 -0.926334 -5.63189 -6.52616 +-23.0922 0.199 -0.907274 -0.328664 -0.495127 -1.17677 0.141477 -0.39451 -0.816737 -0.254086 -0.279208 -0.381025 2.82473 1.027 5.62431 4.98093 8.06169 4.22767 8.28478 6.15559 6.17678 6.6829 +-8.80046 0.083 -0.391495 -0.153935 0.394763 -0.0345221 -0.973245 -1.04625 -0.792164 0.0335939 -0.247152 -0.355054-4.00051 -1.21097 -6.56933 -8.47202 -3.83363 1.81412 -1.56076 -8.66078 2.16866 -6.59245 +12.9892 0.045 -0.604868 -0.437616 -0.261814 -0.300237 -0.50307 -0.513345 -0.116327 -0.755599 -0.456189 0.251793-7.06583 -1.81202 -3.54472 -8.91133 -0.475809 -0.730796 -5.26949 -0.716789 -4.39921 4.02899 +26.0522 0.155 -0.726471 -0.500542 0.463056 0.0172375 0.821945 0.0391786 0.0488004 -0.761927 -0.0771535 -0.677768-3.03305 -0.806344 -5.08316 2.43185 0.0531254 -4.54469 -3.52298 -3.98764 -6.47686 -4.08012 +-0.394286 0.149 -0.402372 -0.31796 -0.222808 0.208382 0.109512 -0.0548755 0.512145 -0.325202 -0.00722632 -1.06763-0.878699 -5.40514 -6.20682 -9.20067 1.41011 -5.61398 -1.49833 2.55979 -5.68378 -4.35992 +0.215663 0.201 -0.422179 -0.126409 -0.93471 -0.374708 -0.663213 -0.442554 -0.479952 -0.31989 -0.301952 -0.232182-1.70318 -9.27917 2.75001 -6.53528 -0.147243 -4.32408 -8.15037 -9.03308 -7.01914 -1.22991 +11.2737 0.173 0.0786274 0.620434 -0.153449 -0.875623 -0.179169 -0.11604 -0.574093 0.759086 -0.473801 -0.44298 0.761977 1.97528 0.245904 4.67894 6.46607 10.2164 -0.481021 8.83011 6.00295 12.6528 +7.31017 0.170 0.554086 -0.329099 0.40787 0.273664 -0.42111 0.62796 0.877994 0.654101 0.178971 -0.11141 3.7597 2.02378 0.249338 -0.175369 -2.11714 0.834232 7.06311 0.392303 4.77186 2.20071 +8.29812 0.048 0.186793 0.104776 0.408931 0.338803 0.0788613 -0.429193 -0.0208904 -0.130811 0.19469 0.33954 0.503046 5.62099 5.10623 8.51691 1.9234 3.02945 8.2911 9.4419 0.0179236 1.51325 +6.24103 0.014 0.0108673 0.438733 -0.314694 0.03981 -0.827548 -0.147591 0.0405775 -0.172693 0.0524953 -0.316098 1.7295 -6.40276 -2.55185 -1.42517 -2.83182 -11.1325 -9.88348 -2.78857 1.28115 -3.45889 +-9.21068 0.021 -0.101516 0.204561 -0.71957 0.164641 0.012674 -0.186643 -0.337984 0.443528 0.0925554 0.0218864 5.1377 -7.38972 -1.99037 -0.468367 -2.23182 -6.04467 -1.83256 -5.46886 -0.333798 1.88979 +16.4724 0.130 -1.1662 -0.685768 -0.570457 -1.01846 -0.489045 -0.511482 0.130923 -1.09909 -0.974636 -0.935703 -2.48501 5.72435 -9.39821 -3.69355 0.451317 -2.24102 -4.04049 -0.810144 -3.10659 -3.54111 +-38.1528 0.002 -0.421105 -0.541814 -0.845877 0.748489 6.49426e-05 -0.258816 0.204953 -0.854529 0.291444 -0.3536782.45106 4.77998 -4.14285 -5.60214 -0.60063 -6.3801 -4.93675 -8.74905 -7.8747 6.22192 +14.6389 0.174 -0.248382 0.0684738 0.431181 0.0539768 -0.0280463 0.308995 0.381971 -0.478037 -0.362165 -0.57462 2.14402 11.1752 6.57662 11.8182 10.6698 -3.1641 -0.258286 2.04417 4.7994 4.27747 +16.4492 0.236 -0.225565 -0.200995 -0.667333 -0.627738 -0.683408 -0.243796 0.261226 -0.27899 -1.058 -0.203284 3.59001 -2.15214 -3.71166 -3.0563 2.58595 -2.04338 -2.38758 -4.06534 -5.14331 -2.42191 +25.8608 0.193 0.389519 1.57712 1.5823 1.2043 1.30529 0.62104 0.82235 0.282229 0.942079 0.778057 -2.70857 -7.76009 2.2184 1.65713 -7.3839 -9.25405 -2.34465 -5.07886 -4.41212 -1.93721 +-9.92573 0.021 -0.304474 -0.314327 0.848129 0.119243 0.0217035 -0.195479 0.428397 -0.422966 0.333868 -0.47922 -0.254762 1.9141 -3.74916 3.2117 0.451984 -2.28391 -4.65881 -1.52544 -5.69967 -6.51559 +3.08785 0.089 1.27418 0.900671 0.566533 1.05645 0.476136 0.602179 1.56866 0.448255 0.559301 0.793959 -3.77359 -5.82907 4.26368 -2.16015 -4.98451 -3.0288 -11.7465 -4.25317 -3.19495 -5.97472 +28.7001 -0.073 -0.604971 -0.163998 0.170379 0.0866151 -0.164901 -0.598475 -0.0869748 -0.342088 -0.214565 0.321035-6.37039 -6.58886 -4.301 -4.36191 -5.35623 -1.50487 -2.96973 -6.89744 -7.92949 -9.61944 +12.371 0.152 0.766531 0.59661 0.854369 -0.40424 0.697286 0.0333006 -0.137105 0.854735 0.66828 0.76212 -3.43466 -7.57344 -11.2585 -1.06124 -1.70824 2.20562 -4.79051 -4.75003 -3.7169 1.5727 +-9.19591 0.464 0.385445 -0.703386 0.233988 -0.338604 -0.600512 -0.0379806 0.169391 -0.399181 -0.872437 -0.171082-9.33911 -3.57512 1.51133 -8.42444 3.3947 -9.92445 -2.44173 -1.36357 -10.1364 -1.98402 +10.4017 0.325 -0.0809564 -0.0286286 0.174555 0.501716 0.0339651 1.33461 0.0724065 0.34989 0.238067 0.170936 -0.0936084 2.53518 10.7079 -1.12088 6.12291 5.02594 11.6854 5.32807 6.23372 2.27904 +-6.921 0.121 -0.612968 0.146224 -0.431335 -0.501208 -0.521683 0.209144 -0.074243 0.585333 0.0682126 -0.662905 -6.08568 -16.4272 -7.94689 1.15848 -4.63711 -1.70608 -1.54744 -3.12326 -4.07782 -10.0512 +-29.3044 0.042 0.205794 -0.0557386 0.344188 -0.637733 -0.342752 -0.241515 -0.634866 -0.414641 0.901712 -0.4266791.22038 -1.41436 -9.26784 -4.03843 -5.44534 0.420501 -4.02771 0.49546 -5.73124 -1.56981 +-33.9694 0.248 0.372695 -0.380325 -0.39018 -0.230175 0.0742885 0.109287 0.550624 -0.273421 -0.275167 -0.0896348 -1.55003 -13.2301 -10.8156 4.49073 5.87843 -0.265556 2.38524 -6.45657 2.98651 1.21781 +-10.077 -0.234 0.697264 0.179724 0.462892 -0.00409393 0.77641 0.33033 0.466961 -0.721023 0.47488 0.259488 -4.03156 -4.28369 2.90612 4.30184 -1.97545 0.149363 -4.40563 -7.33257 -2.26941 -0.902433 +24.6136 0.079 -0.458958 -0.0988292 -1.07617 -0.110539 -0.491435 -0.0796924 -0.0524055 -0.103298 0.39415 -0.459129-8.78459 -5.5183 -3.64398 -2.88999 -0.595605 -4.1143 -6.31779 -1.97276 2.66502 4.42984 +-26.7422 0.605 0.758674 0.309555 0.196882 0.184066 0.656076 0.0639423 0.914242 -0.550106 0.468675 -0.0474171 0.790432 -1.3571 -4.24485 0.475239 2.43845 -7.28404 0.0577858 0.294671 -3.49799 -4.25118 +26.8167 0.286 -0.0533802 -0.41779 0.737187 -1.098 0.304305 -0.548454 -0.152729 -0.273067 0.162294 -0.21638 7.01039 7.51644 4.11495 4.72517 -2.66369 3.66683 7.65931 3.90954 0.75967 4.7317 +32.5135 0.185 -0.493762 -0.760041 0.251586 0.144057 -0.188122 -0.109309 -0.849744 -0.689114 -0.235334 -0.37914614.0304 15.7689 13.5726 17.987 11.6533 8.50892 8.25767 7.73678 12.4089 12.9971 +12.2724 -0.106 0.0917249 0.577368 1.18044 -0.0607781 -0.195451 0.212564 0.200307 -0.121566 -0.744257 0.147472 -1.69748 -3.9815 -4.86789 -10.9888 -3.52272 -5.36006 -0.00795036 -2.47949 -5.14835 0.23732 +11.9821 0.127 0.0261621 -0.261211 0.119872 -0.173093 -0.311519 0.231888 -0.80142 -0.287496 -0.170462 -0.383457 4.31125 4.82924 4.74346 6.78503 -3.45642 1.31127 4.01184 -0.69871 6.42262 0.160736 +-4.59478 0.105 -0.633166 -0.304113 -0.519311 -0.391414 -0.148283 0.321305 -0.381485 -0.889459 -0.599767 -0.1384960.301802 9.9412 2.45688 1.60532 4.11385 13.8166 8.51798 7.97938 -1.21148 6.98434 +-19.4444 0.006 0.167968 -0.201845 -0.257719 -0.152902 -0.467122 -0.464933 -0.419402 -0.240059 -0.200324 -0.3102245.08758 1.76046 -7.19015 5.64902 -0.794235 3.41174 -5.91623 -7.17155 -2.77823 6.19005 +-15.6373 0.116 0.0306145 -0.0145033 -0.127485 0.117823 -0.363023 -0.270852 -0.215192 -0.0871366 0.187042 -0.7250481.31541 -0.170465 5.01602 12.4277 8.47142 9.5005 0.365217 -0.551834 8.90723 7.85349 +-12.9819 -0.031 -0.818857 -0.303336 -0.888151 -0.187542 -1.12369 -0.510763 -1.04366 -0.471315 0.0621281 -0.32589 7.95826 0.759446 0.596682 3.25046 10.5629 -6.39265 4.8928 7.50275 6.22642 10.1084 +-31.6377 0.126 0.0171874 -0.533585 -0.463542 -0.0366132 -0.303316 0.255806 -0.582503 0.735833 0.000379038 0.3706031.19068 -5.11437 -4.36832 -9.40354 -3.00404 -4.00658 -1.18378 -5.75323 -8.21421 -6.08129 +-3.48865 0.213 0.265341 -0.376033 0.438812 -0.88378 -0.797191 -0.564957 0.222085 0.101635 -0.675318 -0.133919 -4.35435 1.10205 -5.06418 -5.68232 2.97645 0.76992 1.23206 -1.4877 -3.44072 -0.815353 +-10.3538 -0.270 -0.787127 0.067107 0.171432 -0.273801 0.0243494 0.400305 -0.0662227 0.193671 -0.188114 -0.461593 6.07491 4.33275 0.615185 1.41238 3.95657 -5.62371 2.98879 7.25598 2.61021 0.265776 +24.8508 0.143 0.0566663 -0.771869 -0.477114 0.209174 0.0827739 -0.374313 -0.0575958 0.7184 -0.318928 -0.300473 3.89767 -5.634 -6.80467 -8.10544 -6.4595 1.0596 -4.95734 -5.81432 -0.279446 -2.20066 +-10.2956 -0.091 0.216404 -0.56851 0.467546 0.191963 0.00881934 -0.531178 -0.577049 -0.788457 -0.828699 -0.448452 -3.6109 -8.29672 -9.13262 1.18399 -3.71325 0.989774 -11.8748 -0.291454 -0.0318805 -6.2376 diff --git a/src/gemma.cpp b/src/gemma.cpp index e3fb005..2af8f8e 100644 --- a/src/gemma.cpp +++ b/src/gemma.cpp @@ -299,7 +299,7 @@ void GEMMA::PrintHelp(size_t option) { cout << " ..." << endl; cout << " missing value: NA" << endl; cout << " -p [filename] " - << " specify input BIMBAM phenotype file name" << endl; + << " specify input BIMBAM-style phenotype file name (when used with PLINK .fam phenotypes are ignored)" << endl; cout << " format: phenotype for individual 1" << endl; cout << " phenotype for individual 2" << endl; cout << " ..." << endl; @@ -1044,7 +1044,7 @@ void GEMMA::Assign(int argc, char **argv, PARAM &cPar) { str.clear(); str.assign(argv[i]); cPar.k_mode = atoi(str.c_str()); - } else if (strcmp(argv[i], "-n") == 0) { // set pheno column (range) + } else if (strcmp(argv[i], "-n") == 0) { // set pheno column (list/range) (cPar.p_column).clear(); while (argv[i + 1] != NULL && argv[i + 1][0] != '-') { ++i; diff --git a/src/io.cpp b/src/io.cpp index bfbfc15..6be01fd 100644 --- a/src/io.cpp +++ b/src/io.cpp @@ -135,6 +135,7 @@ std::istream &safeGetline(std::istream &is, std::string &t) { // Read SNP file. A single column of SNP names. bool ReadFile_snps(const string file_snps, set<string> &setSnps) { + debug_msg("entered"); setSnps.clear(); igzstream infile(file_snps.c_str(), igzstream::in); @@ -162,6 +163,7 @@ bool ReadFile_snps(const string file_snps, set<string> &setSnps) { // values for each row are parsed. A valid header can be, for example, // RS POS CHR bool ReadFile_snps_header(const string &file_snps, set<string> &setSnps) { + debug_msg("entered"); setSnps.clear(); igzstream infile(file_snps.c_str(), igzstream::in); @@ -187,6 +189,7 @@ bool ReadFile_snps_header(const string &file_snps, set<string> &setSnps) { continue; } ch_ptr = strtok((char *)line.c_str(), " , \t"); + enforce_msg(ch_ptr,"Problem reading SNP header"); for (size_t i = 0; i < header.coln; i++) { enforce_msg(ch_ptr,"Problem reading SNP file"); @@ -218,6 +221,7 @@ bool ReadFile_snps_header(const string &file_snps, set<string> &setSnps) { // Read log file. bool ReadFile_log(const string &file_log, double &pheno_mean) { + debug_msg("ReadFile_log"); ifstream infile(file_log.c_str(), ifstream::in); if (!infile) { cout << "error! fail to open log file: " << file_log << endl; @@ -259,6 +263,7 @@ bool ReadFile_log(const string &file_log, double &pheno_mean) { bool ReadFile_anno(const string &file_anno, map<string, string> &mapRS2chr, map<string, long int> &mapRS2bp, map<string, double> &mapRS2cM) { + debug_msg("ReadFile_anno"); mapRS2chr.clear(); mapRS2bp.clear(); @@ -318,6 +323,7 @@ bool ReadFile_anno(const string &file_anno, map<string, string> &mapRS2chr, // Read 1 column of phenotype. bool ReadFile_column(const string &file_pheno, vector<int> &indicator_idv, vector<double> &pheno, const int &p_column) { + debug_msg("entered"); indicator_idv.clear(); pheno.clear(); @@ -337,11 +343,11 @@ bool ReadFile_column(const string &file_pheno, vector<int> &indicator_idv, for (int i = 0; i < (p_column - 1); ++i) { ch_ptr = strtok(NULL, " , \t"); } + enforce_msg(ch_ptr,"Problem reading PHENO column"); if (strcmp(ch_ptr, "NA") == 0) { indicator_idv.push_back(0); pheno.push_back(-9); } else { - // Pheno is different from pimass2. p = atof(ch_ptr); indicator_idv.push_back(1); @@ -360,6 +366,7 @@ bool ReadFile_pheno(const string &file_pheno, vector<vector<int>> &indicator_pheno, vector<vector<double>> &pheno, const vector<size_t> &p_column) { + debug_msg("entered"); indicator_pheno.clear(); pheno.clear(); @@ -390,7 +397,7 @@ bool ReadFile_pheno(const string &file_pheno, ch_ptr = strtok((char *)line.c_str(), " , \t"); size_t i = 0; while (i < p_max) { - enforce_msg(ch_ptr,"Wrong number of phenotypes"); + enforce_msg(ch_ptr,"Number of phenotypes out of range"); if (mapP2c.count(i + 1) != 0) { if (strcmp(ch_ptr, "NA") == 0) { ind_pheno_row[mapP2c[i + 1]] = 0; @@ -417,6 +424,7 @@ bool ReadFile_pheno(const string &file_pheno, bool ReadFile_cvt(const string &file_cvt, vector<int> &indicator_cvt, vector<vector<double>> &cvt, size_t &n_cvt) { + debug_msg("entered"); indicator_cvt.clear(); ifstream infile(file_cvt.c_str(), ifstream::in); @@ -483,6 +491,7 @@ bool ReadFile_cvt(const string &file_cvt, vector<int> &indicator_cvt, // Read .bim file. bool ReadFile_bim(const string &file_bim, vector<SNPINFO> &snpInfo) { + debug_msg("entered"); snpInfo.clear(); ifstream infile(file_bim.c_str(), ifstream::in); @@ -524,10 +533,11 @@ bool ReadFile_bim(const string &file_bim, vector<SNPINFO> &snpInfo) { return true; } -// Read .fam file. +// Read .fam file (ignored with -p phenotypes switch) bool ReadFile_fam(const string &file_fam, vector<vector<int>> &indicator_pheno, vector<vector<double>> &pheno, map<string, int> &mapID2num, const vector<size_t> &p_column) { + debug_msg("entered"); indicator_pheno.clear(); pheno.clear(); mapID2num.clear(); @@ -568,6 +578,8 @@ bool ReadFile_fam(const string &file_fam, vector<vector<int>> &indicator_pheno, size_t i = 0; while (i < p_max) { if (mapP2c.count(i + 1) != 0) { + enforce_msg(ch_ptr,"Problem reading FAM file (phenotypes out of range)"); + if (strcmp(ch_ptr, "NA") == 0) { ind_pheno_row[mapP2c[i + 1]] = 0; pheno_row[mapP2c[i + 1]] = -9; @@ -609,6 +621,7 @@ bool ReadFile_geno(const string &file_geno, const set<string> &setSnps, map<string, long int> &mapRS2bp, map<string, double> &mapRS2cM, vector<SNPINFO> &snpInfo, size_t &ns_test, bool debug) { + debug_msg("entered"); indicator_snp.clear(); snpInfo.clear(); @@ -819,6 +832,7 @@ bool ReadFile_bed(const string &file_bed, const set<string> &setSnps, const double &maf_level, const double &miss_level, const double &hwe_level, const double &r2_level, size_t &ns_test) { + debug_msg("entered"); indicator_snp.clear(); size_t ns_total = snpInfo.size(); @@ -1007,6 +1021,7 @@ bool ReadFile_bed(const string &file_bed, const set<string> &setSnps, // Missing values are replaced by mean. bool Bimbam_ReadOneSNP(const size_t inc, const vector<int> &indicator_idv, igzstream &infile, gsl_vector *geno, double &geno_mean) { + debug_msg("entered"); size_t ni_total = indicator_idv.size(); string line; @@ -1057,6 +1072,7 @@ bool Bimbam_ReadOneSNP(const size_t inc, const vector<int> &indicator_idv, // For PLINK, store SNPs as double too. void Plink_ReadOneSNP(const int pos, const vector<int> &indicator_idv, ifstream &infile, gsl_vector *geno, double &geno_mean) { + debug_msg("entered"); size_t ni_total = indicator_idv.size(), n_bit; if (ni_total % 4 == 0) { n_bit = ni_total / 4; @@ -1123,6 +1139,7 @@ void Plink_ReadOneSNP(const int pos, const vector<int> &indicator_idv, void ReadFile_kin(const string &file_kin, vector<int> &indicator_idv, map<string, int> &mapID2num, const size_t k_mode, bool &error, gsl_matrix *G) { + debug_msg("entered"); igzstream infile(file_kin.c_str(), igzstream::in); if (!infile) { cout << "error! fail to open kinship file: " << file_kin << endl; @@ -1239,6 +1256,7 @@ void ReadFile_kin(const string &file_kin, vector<int> &indicator_idv, void ReadFile_mk(const string &file_mk, vector<int> &indicator_idv, map<string, int> &mapID2num, const size_t k_mode, bool &error, gsl_matrix *G) { + debug_msg("entered"); igzstream infile(file_mk.c_str(), igzstream::in); if (!infile) { cout << "error! fail to open file: " << file_mk << endl; @@ -1264,6 +1282,7 @@ void ReadFile_mk(const string &file_mk, vector<int> &indicator_idv, } void ReadFile_eigenU(const string &file_ku, bool &error, gsl_matrix *U) { + debug_msg("entered"); igzstream infile(file_ku.c_str(), igzstream::in); if (!infile) { cout << "error! fail to open the U file: " << file_ku << endl; @@ -1312,6 +1331,7 @@ void ReadFile_eigenU(const string &file_ku, bool &error, gsl_matrix *U) { } void ReadFile_eigenD(const string &file_kd, bool &error, gsl_vector *eval) { + debug_msg("entered"); igzstream infile(file_kd.c_str(), igzstream::in); if (!infile) { cout << "error! fail to open the D file: " << file_kd << endl; @@ -1360,6 +1380,7 @@ bool BimbamKin(const string file_geno, const set<string> ksnps, vector<int> &indicator_snp, const int k_mode, const int display_pace, gsl_matrix *matrix_kin, const bool test_nind) { + debug_msg("entered"); igzstream infile(file_geno.c_str(), igzstream::in); enforce_msg(infile, "error reading genotype file"); @@ -1496,6 +1517,7 @@ bool BimbamKin(const string file_geno, const set<string> ksnps, bool PlinkKin(const string &file_bed, vector<int> &indicator_snp, const int k_mode, const int display_pace, gsl_matrix *matrix_kin) { + debug_msg("entered"); ifstream infile(file_bed.c_str(), ios::binary); if (!infile) { cout << "error reading bed file:" << file_bed << endl; @@ -1638,6 +1660,7 @@ bool PlinkKin(const string &file_bed, vector<int> &indicator_snp, bool ReadFile_geno(const string file_geno, vector<int> &indicator_idv, vector<int> &indicator_snp, gsl_matrix *UtX, gsl_matrix *K, const bool calc_K, bool debug) { + debug_msg("entered"); igzstream infile(file_geno.c_str(), igzstream::in); if (!infile) { cout << "error reading genotype file:" << file_geno << endl; @@ -1742,6 +1765,7 @@ bool ReadFile_geno(const string &file_geno, vector<int> &indicator_idv, vector<vector<unsigned char>> &Xt, gsl_matrix *K, const bool calc_K, const size_t ni_test, const size_t ns_test, bool debug) { + debug_msg("entered"); igzstream infile(file_geno.c_str(), igzstream::in); if (!infile) { cout << "error reading genotype file:" << file_geno << endl; @@ -1848,6 +1872,7 @@ bool ReadFile_geno(const string &file_geno, vector<int> &indicator_idv, bool ReadFile_bed(const string &file_bed, vector<int> &indicator_idv, vector<int> &indicator_snp, gsl_matrix *UtX, gsl_matrix *K, const bool calc_K) { + debug_msg("entered"); ifstream infile(file_bed.c_str(), ios::binary); if (!infile) { cout << "error reading bed file:" << file_bed << endl; @@ -1979,6 +2004,7 @@ bool ReadFile_bed(const string &file_bed, vector<int> &indicator_idv, vector<int> &indicator_snp, vector<vector<unsigned char>> &Xt, gsl_matrix *K, const bool calc_K, const size_t ni_test, const size_t ns_test) { + debug_msg("entered"); ifstream infile(file_bed.c_str(), ios::binary); if (!infile) { cout << "error reading bed file:" << file_bed << endl; @@ -2113,6 +2139,7 @@ bool ReadFile_bed(const string &file_bed, vector<int> &indicator_idv, bool ReadFile_est(const string &file_est, const vector<size_t> &est_column, map<string, double> &mapRS2est) { + debug_msg("entered"); mapRS2est.clear(); ifstream infile(file_est.c_str(), ifstream::in); @@ -2173,6 +2200,7 @@ bool ReadFile_est(const string &file_est, const vector<size_t> &est_column, } bool CountFileLines(const string &file_input, size_t &n_lines) { + debug_msg("entered"); igzstream infile(file_input.c_str(), igzstream::in); if (!infile) { cout << "error! fail to open file: " << file_input << endl; @@ -2189,6 +2217,7 @@ bool CountFileLines(const string &file_input, size_t &n_lines) { // Read gene expression file. bool ReadFile_gene(const string &file_gene, vector<double> &vec_read, vector<SNPINFO> &snpInfo, size_t &ng_total) { + debug_msg("entered"); vec_read.clear(); ng_total = 0; @@ -2252,6 +2281,7 @@ bool ReadFile_sample(const string &file_sample, vector<vector<double>> &pheno, const vector<size_t> &p_column, vector<int> &indicator_cvt, vector<vector<double>> &cvt, size_t &n_cvt) { + debug_msg("entered"); indicator_pheno.clear(); pheno.clear(); indicator_cvt.clear(); @@ -2506,6 +2536,7 @@ bool ReadFile_bgen(const string &file_bgen, const set<string> &setSnps, const double &hwe_level, const double &r2_level, size_t &ns_test) { + debug_msg("entered"); indicator_snp.clear(); ifstream infile(file_bgen.c_str(), ios::binary); @@ -2793,6 +2824,7 @@ bool ReadFile_bgen(const string &file_bgen, const set<string> &setSnps, // Read oxford genotype file and calculate kinship matrix. bool bgenKin(const string &file_oxford, vector<int> &indicator_snp, const int k_mode, const int display_pace, gsl_matrix *matrix_kin) { + debug_msg("entered"); string file_bgen = file_oxford; ifstream infile(file_bgen.c_str(), ios::binary); if (!infile) { @@ -2851,7 +2883,7 @@ bool bgenKin(const string &file_oxford, vector<int> &indicator_snp, for (size_t t = 0; t < indicator_snp.size(); ++t) { if (t % display_pace == 0 || t == (indicator_snp.size() - 1)) { - ProgressBar("Reading SNPs ", t, indicator_snp.size() - 1); + ProgressBar("Reading bgen SNPs ", t, indicator_snp.size() - 1); } id.clear(); @@ -2997,6 +3029,7 @@ bool bgenKin(const string &file_oxford, vector<int> &indicator_snp, // Read header to determine which column contains which item. bool ReadHeader_io(const string &line, HEADER &header) { + debug_msg("entered"); string rs_ptr[] = {"rs", "RS", "snp", "SNP", "snps", "SNPS", "snpid", "SNPID", "rsid", "RSID", "MarkerName"}; set<string> rs_set(rs_ptr, rs_ptr + 11); // create a set of 11 items @@ -3264,6 +3297,7 @@ bool ReadHeader_io(const string &line, HEADER &header) { // it is not included in the analysis. bool ReadFile_cat(const string &file_cat, map<string, size_t> &mapRS2cat, size_t &n_vc) { + debug_msg("entered"); mapRS2cat.clear(); igzstream infile(file_cat.c_str(), igzstream::in); @@ -3348,6 +3382,7 @@ bool ReadFile_cat(const string &file_cat, map<string, size_t> &mapRS2cat, bool ReadFile_mcat(const string &file_mcat, map<string, size_t> &mapRS2cat, size_t &n_vc) { + debug_msg("entered"); mapRS2cat.clear(); igzstream infile(file_mcat.c_str(), igzstream::in); @@ -3386,6 +3421,8 @@ bool BimbamKinUncentered(const string &file_geno, const set<string> ksnps, const map<string, size_t> &mapRS2cat, const vector<SNPINFO> &snpInfo, const gsl_matrix *W, gsl_matrix *matrix_kin, gsl_vector *vector_ns) { + debug_msg("entered"); + debug_msg("BimbamKinUncentered"); igzstream infile(file_geno.c_str(), igzstream::in); if (!infile) { cout << "error reading genotype file:" << file_geno << endl; @@ -3576,6 +3613,7 @@ bool PlinkKin(const string &file_bed, const int display_pace, const map<string, size_t> &mapRS2cat, const vector<SNPINFO> &snpInfo, const gsl_matrix *W, gsl_matrix *matrix_kin, gsl_vector *vector_ns) { + debug_msg("entered"); ifstream infile(file_bed.c_str(), ios::binary); if (!infile) { cout << "error reading bed file:" << file_bed << endl; @@ -3801,6 +3839,7 @@ bool MFILEKin(const size_t mfile_mode, const string &file_mfile, const map<string, size_t> &mapRS2cat, const vector<vector<SNPINFO>> &msnpInfo, const gsl_matrix *W, gsl_matrix *matrix_kin, gsl_vector *vector_ns) { + debug_msg("entered"); size_t n_vc = vector_ns->size, ni_test = matrix_kin->size1; gsl_matrix_set_zero(matrix_kin); gsl_vector_set_zero(vector_ns); @@ -3876,6 +3915,7 @@ bool MFILEKin(const size_t mfile_mode, const string &file_mfile, // Read var file, store mapRS2wsnp. bool ReadFile_wsnp(const string &file_wsnp, map<string, double> &mapRS2weight) { + debug_msg("entered"); mapRS2weight.clear(); igzstream infile(file_wsnp.c_str(), igzstream::in); @@ -3901,6 +3941,7 @@ bool ReadFile_wsnp(const string &file_wsnp, map<string, double> &mapRS2weight) { bool ReadFile_wsnp(const string &file_wcat, const size_t n_vc, map<string, vector<double>> &mapRS2wvector) { + debug_msg("entered"); mapRS2wvector.clear(); igzstream infile(file_wcat.c_str(), igzstream::in); @@ -3985,6 +4026,7 @@ void ReadFile_beta(const string &file_beta, vector<size_t> &vec_ni, vector<double> &vec_weight, vector<double> &vec_z2, size_t &ni_total, size_t &ns_total, size_t &ns_test) { + debug_msg("entered"); vec_cat.clear(); vec_ni.clear(); vec_weight.clear(); @@ -4171,6 +4213,7 @@ void ReadFile_beta(const string &file_beta, void ReadFile_beta(const string &file_beta, const map<string, double> &mapRS2wA, map<string, string> &mapRS2A1, map<string, double> &mapRS2z) { + debug_msg("entered"); mapRS2A1.clear(); mapRS2z.clear(); @@ -4332,6 +4375,7 @@ void Calcq(const size_t n_block, const vector<size_t> &vec_cat, const vector<size_t> &vec_ni, const vector<double> &vec_weight, const vector<double> &vec_z2, gsl_matrix *Vq, gsl_vector *q, gsl_vector *s) { + debug_msg("entered"); gsl_matrix_set_zero(Vq); gsl_vector_set_zero(q); gsl_vector_set_zero(s); @@ -4485,6 +4529,7 @@ void Calcq(const size_t n_block, const vector<size_t> &vec_cat, // Read vector file. void ReadFile_vector(const string &file_vec, gsl_vector *vec) { + debug_msg("entered"); igzstream infile(file_vec.c_str(), igzstream::in); if (!infile) { cout << "error! fail to open vector file: " << file_vec << endl; @@ -4507,6 +4552,7 @@ void ReadFile_vector(const string &file_vec, gsl_vector *vec) { } void ReadFile_matrix(const string &file_mat, gsl_matrix *mat) { + debug_msg("entered"); igzstream infile(file_mat.c_str(), igzstream::in); if (!infile) { cout << "error! fail to open matrix file: " << file_mat << endl; @@ -4533,6 +4579,7 @@ void ReadFile_matrix(const string &file_mat, gsl_matrix *mat) { void ReadFile_matrix(const string &file_mat, gsl_matrix *mat1, gsl_matrix *mat2) { + debug_msg("entered"); igzstream infile(file_mat.c_str(), igzstream::in); if (!infile) { cout << "error! fail to open matrix file: " << file_mat << endl; @@ -4569,6 +4616,7 @@ void ReadFile_matrix(const string &file_mat, gsl_matrix *mat1, // Read study file. void ReadFile_study(const string &file_study, gsl_matrix *Vq_mat, gsl_vector *q_vec, gsl_vector *s_vec, size_t &ni) { + debug_msg("entered"); string Vqfile = file_study + ".Vq.txt"; string sfile = file_study + ".size.txt"; string qfile = file_study + ".q.txt"; @@ -4594,6 +4642,7 @@ void ReadFile_study(const string &file_study, gsl_matrix *Vq_mat, // Read reference file. void ReadFile_ref(const string &file_ref, gsl_matrix *S_mat, gsl_matrix *Svar_mat, gsl_vector *s_vec, size_t &ni) { + debug_msg("entered"); string sfile = file_ref + ".size.txt"; string Sfile = file_ref + ".S.txt"; @@ -4617,6 +4666,7 @@ void ReadFile_ref(const string &file_ref, gsl_matrix *S_mat, // Read mstudy file. void ReadFile_mstudy(const string &file_mstudy, gsl_matrix *Vq_mat, gsl_vector *q_vec, gsl_vector *s_vec, size_t &ni) { + debug_msg("entered"); gsl_matrix_set_zero(Vq_mat); gsl_vector_set_zero(q_vec); gsl_vector_set_zero(s_vec); @@ -4707,6 +4757,7 @@ void ReadFile_mstudy(const string &file_mstudy, gsl_matrix *Vq_mat, // Read reference file. void ReadFile_mref(const string &file_mref, gsl_matrix *S_mat, gsl_matrix *Svar_mat, gsl_vector *s_vec, size_t &ni) { + debug_msg("entered"); gsl_matrix_set_zero(S_mat); gsl_matrix_set_zero(Svar_mat); gsl_vector_set_zero(s_vec); diff --git a/src/lm.cpp b/src/lm.cpp index f8fc43d..0c2a2bb 100644 --- a/src/lm.cpp +++ b/src/lm.cpp @@ -290,6 +290,7 @@ void LmCalcP(const size_t test_mode, const double yPwy, const double xPwy, } void LM::AnalyzeGene(const gsl_matrix *W, const gsl_vector *x) { + debug_msg("entering"); ifstream infile(file_gene.c_str(), ifstream::in); if (!infile) { cout << "error reading gene expression file:" << file_gene << endl; @@ -361,7 +362,7 @@ void LM::AnalyzeGene(const gsl_matrix *W, const gsl_vector *x) { time_opt += (clock() - time_start) / (double(CLOCKS_PER_SEC) * 60.0); // Store summary data. - SUMSTAT SNPs = {beta, se, 0.0, 0.0, p_wald, p_lrt, p_score}; + SUMSTAT SNPs = {beta, se, 0.0, 0.0, p_wald, p_lrt, p_score, -0.0 }; sumStat.push_back(SNPs); } cout << endl; @@ -382,6 +383,7 @@ void LM::AnalyzeGene(const gsl_matrix *W, const gsl_vector *x) { // WJA added void LM::Analyzebgen(const gsl_matrix *W, const gsl_vector *y) { + debug_msg("entering"); string file_bgen = file_oxford + ".bgen"; ifstream infile(file_bgen.c_str(), ios::binary); if (!infile) { @@ -585,7 +587,7 @@ void LM::Analyzebgen(const gsl_matrix *W, const gsl_vector *y) { time_opt += (clock() - time_start) / (double(CLOCKS_PER_SEC) * 60.0); // Store summary data. - SUMSTAT SNPs = {beta, se, 0.0, 0.0, p_wald, p_lrt, p_score}; + SUMSTAT SNPs = {beta, se, 0.0, 0.0, p_wald, p_lrt, p_score, -0.0}; sumStat.push_back(SNPs); } cout << endl; @@ -606,6 +608,7 @@ void LM::Analyzebgen(const gsl_matrix *W, const gsl_vector *y) { } void LM::AnalyzeBimbam(const gsl_matrix *W, const gsl_vector *y) { + debug_msg("entering"); igzstream infile(file_geno.c_str(), igzstream::in); if (!infile) { cout << "error reading genotype file:" << file_geno << endl; @@ -699,7 +702,7 @@ void LM::AnalyzeBimbam(const gsl_matrix *W, const gsl_vector *y) { time_opt += (clock() - time_start) / (double(CLOCKS_PER_SEC) * 60.0); // Store summary data. - SUMSTAT SNPs = {beta, se, 0.0, 0.0, p_wald, p_lrt, p_score}; + SUMSTAT SNPs = {beta, se, 0.0, 0.0, p_wald, p_lrt, p_score, -0.0}; sumStat.push_back(SNPs); } cout << endl; @@ -720,6 +723,7 @@ void LM::AnalyzeBimbam(const gsl_matrix *W, const gsl_vector *y) { } void LM::AnalyzePlink(const gsl_matrix *W, const gsl_vector *y) { + debug_msg("entering"); string file_bed = file_bfile + ".bed"; ifstream infile(file_bed.c_str(), ios::binary); if (!infile) { @@ -840,7 +844,7 @@ void LM::AnalyzePlink(const gsl_matrix *W, const gsl_vector *y) { p_lrt, p_score); // store summary data - SUMSTAT SNPs = {beta, se, 0.0, 0.0, p_wald, p_lrt, p_score}; + SUMSTAT SNPs = {beta, se, 0.0, 0.0, p_wald, p_lrt, p_score, -0.0}; sumStat.push_back(SNPs); time_opt += (clock() - time_start) / (double(CLOCKS_PER_SEC) * 60.0); diff --git a/src/lmm.cpp b/src/lmm.cpp index eb76265..1193700 100644 --- a/src/lmm.cpp +++ b/src/lmm.cpp @@ -95,6 +95,7 @@ void LMM::CopyToParam(PARAM &cPar) { } void LMM::WriteFiles() { + string file_str; file_str = path_out + "/" + file_out; file_str += ".assoc.txt"; @@ -105,150 +106,105 @@ void LMM::WriteFiles() { return; } - if (!file_gene.empty()) { - outfile << "geneID" - << "\t"; - - if (a_mode == 1) { - outfile << "beta" - << "\t" - << "se" - << "\t" - << "l_remle" - << "\t" + auto common_header = [&] () { + if (a_mode != 2) + outfile << "beta" << "\t"; + + outfile << "se" << "\t"; + + outfile << "logl_H1" << "\t"; // we may make this an option + + switch(a_mode) { + case 1: + outfile << "l_remle" << "\t" << "p_wald" << endl; - } else if (a_mode == 2) { - outfile << "l_mle" - << "\t" + break; + case 2: + outfile << "l_mle" << "\t" << "p_lrt" << endl; - } else if (a_mode == 3) { - outfile << "beta" - << "\t" - << "se" - << "\t" - << "p_score" << endl; - } else if (a_mode == 4) { - outfile << "beta" - << "\t" - << "se" - << "\t" - << "l_remle" - << "\t" - << "l_mle" - << "\t" - << "p_wald" - << "\t" - << "p_lrt" - << "\t" + break; + case 3: + outfile << "p_score" << endl; + break; + case 4: + outfile << "l_remle" << "\t" + << "l_mle" << "\t" + << "p_wald" << "\t" + << "p_lrt" << "\t" << "p_score" << endl; - } else { + break; } + }; + + auto sumstats = [&] (SUMSTAT st) { + outfile << scientific << setprecision(6); + + if (a_mode != 2) + outfile << st.beta << "\t"; + + outfile << st.se << "\t"; + + outfile << st.logl_H1 << "\t"; + + switch(a_mode) { + case 1: + outfile << st.lambda_remle << "\t" + << st.p_wald << endl; + break; + case 2: + outfile << st.lambda_mle << "\t" + << st.p_lrt << endl; + break; + case 3: + outfile << st.p_score << endl; + break; + case 4: + outfile << st.lambda_remle << "\t" + << st.lambda_mle << "\t" + << st.p_wald << "\t" + << st.p_lrt << "\t" + << st.p_score << endl; + break; + } + }; + + + if (!file_gene.empty()) { + outfile << "geneID" << "\t"; + + common_header(); for (vector<SUMSTAT>::size_type t = 0; t < sumStat.size(); ++t) { outfile << snpInfo[t].rs_number << "\t"; - - if (a_mode == 1) { - outfile << scientific << setprecision(6) << sumStat[t].beta << "\t" - << sumStat[t].se << "\t" << sumStat[t].lambda_remle << "\t" - << sumStat[t].p_wald << endl; - } else if (a_mode == 2) { - outfile << scientific << setprecision(6) << sumStat[t].lambda_mle - << "\t" << sumStat[t].p_lrt << endl; - } else if (a_mode == 3) { - outfile << scientific << setprecision(6) << sumStat[t].beta << "\t" - << sumStat[t].se << "\t" << sumStat[t].p_score << endl; - } else if (a_mode == 4) { - outfile << scientific << setprecision(6) << sumStat[t].beta << "\t" - << sumStat[t].se << "\t" << sumStat[t].lambda_remle << "\t" - << sumStat[t].lambda_mle << "\t" << sumStat[t].p_wald << "\t" - << sumStat[t].p_lrt << "\t" << sumStat[t].p_score << endl; - } else { - } + sumstats(sumStat[t]); } } else { bool process_gwasnps = setGWASnps.size(); - outfile << "chr" - << "\t" - << "rs" - << "\t" - << "ps" - << "\t" - << "n_miss" - << "\t" - << "allele1" - << "\t" - << "allele0" - << "\t" - << "af" - << "\t"; - - if (a_mode == 1) { - outfile << "beta" - << "\t" - << "se" - << "\t" - << "l_remle" - << "\t" - << "p_wald" << endl; - } else if (a_mode == 2) { - outfile << "l_mle" - << "\t" - << "p_lrt" << endl; - } else if (a_mode == 3) { - outfile << "beta" - << "\t" - << "se" - << "\t" - << "p_score" << endl; - } else if (a_mode == 4) { - outfile << "beta" - << "\t" - << "se" - << "\t" - << "l_remle" - << "\t" - << "l_mle" - << "\t" - << "p_wald" - << "\t" - << "p_lrt" - << "\t" - << "p_score" << endl; - } else { - } + + outfile << "chr" << "\t" + << "rs" << "\t" + << "ps" << "\t" + << "n_miss" << "\t" + << "allele1" << "\t" + << "allele0" << "\t" + << "af" << "\t"; + + common_header(); size_t t = 0; for (size_t i = 0; i < snpInfo.size(); ++i) { - if (indicator_snp[i] == 0) continue; auto snp = snpInfo[i].rs_number; if (process_gwasnps && setGWASnps.count(snp) == 0) continue; // cout << t << endl; - outfile << snpInfo[i].chr << "\t" << snpInfo[i].rs_number << "\t" << snpInfo[i].base_position << "\t" << snpInfo[i].n_miss << "\t" << snpInfo[i].a_minor << "\t" << snpInfo[i].a_major << "\t" << fixed << setprecision(3) << snpInfo[i].maf << "\t"; - if (a_mode == 1) { - outfile << scientific << setprecision(6) << sumStat[t].beta << "\t" - << sumStat[t].se << "\t" << sumStat[t].lambda_remle << "\t" - << sumStat[t].p_wald << endl; - } else if (a_mode == 2) { - outfile << scientific << setprecision(6) << sumStat[t].lambda_mle - << "\t" << sumStat[t].p_lrt << endl; - } else if (a_mode == 3) { - outfile << scientific << setprecision(6) << sumStat[t].beta << "\t" - << sumStat[t].se << "\t" << sumStat[t].p_score << endl; - } else if (a_mode == 4) { - outfile << scientific << setprecision(6) << sumStat[t].beta << "\t" - << sumStat[t].se << "\t" << sumStat[t].lambda_remle << "\t" - << sumStat[t].lambda_mle << "\t" << sumStat[t].p_wald << "\t" - << sumStat[t].p_lrt << "\t" << sumStat[t].p_score << endl; - } else { - } + sumstats(sumStat[t]); t++; } } @@ -1299,7 +1255,7 @@ void LMM::AnalyzeGene(const gsl_matrix *U, const gsl_vector *eval, time_opt += (clock() - time_start) / (double(CLOCKS_PER_SEC) * 60.0); // Store summary data. - SUMSTAT SNPs = {beta, se, lambda_remle, lambda_mle, p_wald, p_lrt, p_score}; + SUMSTAT SNPs = {beta, se, lambda_remle, lambda_mle, p_wald, p_lrt, p_score, logl_H1}; sumStat.push_back(SNPs); } cout << endl; @@ -1319,6 +1275,7 @@ void LMM::AnalyzeBimbam(const gsl_matrix *U, const gsl_vector *eval, const gsl_matrix *UtW, const gsl_vector *Uty, const gsl_matrix *W, const gsl_vector *y, const set<string> gwasnps) { + debug_msg("entering"); clock_t time_start = clock(); // LOCO support @@ -1399,7 +1356,7 @@ void LMM::AnalyzeBimbam(const gsl_matrix *U, const gsl_vector *eval, // Store summary data. SUMSTAT SNPs = {beta, se, lambda_remle, lambda_mle, - p_wald, p_lrt, p_score}; + p_wald, p_lrt, p_score, logl_H1}; sumStat.push_back(SNPs); } }; @@ -1482,6 +1439,7 @@ void LMM::AnalyzeBimbam(const gsl_matrix *U, const gsl_vector *eval, void LMM::AnalyzePlink(const gsl_matrix *U, const gsl_vector *eval, const gsl_matrix *UtW, const gsl_vector *Uty, const gsl_matrix *W, const gsl_vector *y) { + debug_msg("entering"); string file_bed = file_bfile + ".bed"; ifstream infile(file_bed.c_str(), ios::binary); if (!infile) { @@ -1651,7 +1609,7 @@ void LMM::AnalyzePlink(const gsl_matrix *U, const gsl_vector *eval, // Store summary data. SUMSTAT SNPs = {beta, se, lambda_remle, lambda_mle, - p_wald, p_lrt, p_score}; + p_wald, p_lrt, p_score, logl_H1}; sumStat.push_back(SNPs); } } @@ -1676,6 +1634,7 @@ void LMM::AnalyzePlink(const gsl_matrix *U, const gsl_vector *eval, void LMM::Analyzebgen(const gsl_matrix *U, const gsl_vector *eval, const gsl_matrix *UtW, const gsl_vector *Uty, const gsl_matrix *W, const gsl_vector *y) { + debug_msg("entering"); string file_bgen = file_oxford + ".bgen"; ifstream infile(file_bgen.c_str(), ios::binary); if (!infile) { @@ -1927,7 +1886,7 @@ void LMM::Analyzebgen(const gsl_matrix *U, const gsl_vector *eval, // Store summary data. SUMSTAT SNPs = {beta, se, lambda_remle, lambda_mle, - p_wald, p_lrt, p_score}; + p_wald, p_lrt, p_score, logl_H1}; sumStat.push_back(SNPs); } } @@ -2282,6 +2241,7 @@ void LMM::AnalyzeBimbamGXE(const gsl_matrix *U, const gsl_vector *eval, const gsl_matrix *UtW, const gsl_vector *Uty, const gsl_matrix *W, const gsl_vector *y, const gsl_vector *env) { + debug_msg("entering"); igzstream infile(file_geno.c_str(), igzstream::in); if (!infile) { cout << "error reading genotype file:" << file_geno << endl; @@ -2407,7 +2367,7 @@ void LMM::AnalyzeBimbamGXE(const gsl_matrix *U, const gsl_vector *eval, time_opt += (clock() - time_start) / (double(CLOCKS_PER_SEC) * 60.0); // Store summary data. - SUMSTAT SNPs = {beta, se, lambda_remle, lambda_mle, p_wald, p_lrt, p_score}; + SUMSTAT SNPs = {beta, se, lambda_remle, lambda_mle, p_wald, p_lrt, p_score, logl_H1}; sumStat.push_back(SNPs); } cout << endl; @@ -2430,6 +2390,7 @@ void LMM::AnalyzePlinkGXE(const gsl_matrix *U, const gsl_vector *eval, const gsl_matrix *UtW, const gsl_vector *Uty, const gsl_matrix *W, const gsl_vector *y, const gsl_vector *env) { + debug_msg("entering"); string file_bed = file_bfile + ".bed"; ifstream infile(file_bed.c_str(), ios::binary); if (!infile) { @@ -2584,7 +2545,7 @@ void LMM::AnalyzePlinkGXE(const gsl_matrix *U, const gsl_vector *eval, time_opt += (clock() - time_start) / (double(CLOCKS_PER_SEC) * 60.0); // Store summary data. - SUMSTAT SNPs = {beta, se, lambda_remle, lambda_mle, p_wald, p_lrt, p_score}; + SUMSTAT SNPs = {beta, se, lambda_remle, lambda_mle, p_wald, p_lrt, p_score, logl_H1}; sumStat.push_back(SNPs); } cout << endl; diff --git a/src/mvlmm.cpp b/src/mvlmm.cpp index be9fd78..c5efb6e 100644 --- a/src/mvlmm.cpp +++ b/src/mvlmm.cpp @@ -2953,6 +2953,7 @@ double PCRT(const size_t mode, const size_t d_size, const double p_value, // WJA added. void MVLMM::Analyzebgen(const gsl_matrix *U, const gsl_vector *eval, const gsl_matrix *UtW, const gsl_matrix *UtY) { + debug_msg("entering"); string file_bgen = file_oxford + ".bgen"; ifstream infile(file_bgen.c_str(), ios::binary); if (!infile) { @@ -3501,6 +3502,7 @@ void MVLMM::Analyzebgen(const gsl_matrix *U, const gsl_vector *eval, void MVLMM::AnalyzeBimbam(const gsl_matrix *U, const gsl_vector *eval, const gsl_matrix *UtW, const gsl_matrix *UtY) { + debug_msg("entering"); igzstream infile(file_geno.c_str(), igzstream::in); if (!infile) { cout << "error reading genotype file:" << file_geno << endl; @@ -3938,6 +3940,7 @@ void MVLMM::AnalyzeBimbam(const gsl_matrix *U, const gsl_vector *eval, void MVLMM::AnalyzePlink(const gsl_matrix *U, const gsl_vector *eval, const gsl_matrix *UtW, const gsl_matrix *UtY) { + debug_msg("entering"); string file_bed = file_bfile + ".bed"; ifstream infile(file_bed.c_str(), ios::binary); if (!infile) { @@ -4475,6 +4478,7 @@ void CalcMvLmmVgVeBeta(const gsl_vector *eval, const gsl_matrix *UtW, void MVLMM::AnalyzeBimbamGXE(const gsl_matrix *U, const gsl_vector *eval, const gsl_matrix *UtW, const gsl_matrix *UtY, const gsl_vector *env) { + debug_msg("entering"); igzstream infile(file_geno.c_str(), igzstream::in); if (!infile) { cout << "error reading genotype file:" << file_geno << endl; @@ -4920,6 +4924,7 @@ void MVLMM::AnalyzeBimbamGXE(const gsl_matrix *U, const gsl_vector *eval, void MVLMM::AnalyzePlinkGXE(const gsl_matrix *U, const gsl_vector *eval, const gsl_matrix *UtW, const gsl_matrix *UtY, const gsl_vector *env) { + debug_msg("entering"); string file_bed = file_bfile + ".bed"; ifstream infile(file_bed.c_str(), ios::binary); if (!infile) { diff --git a/src/param.h b/src/param.h index 08b1e10..ff279bd 100644 --- a/src/param.h +++ b/src/param.h @@ -56,6 +56,9 @@ public: double p_wald; // p value from a Wald test. double p_lrt; // p value from a likelihood ratio test. double p_score; // p value from a score test. + double logl_H1; // log likelihood under the alternative + // hypothesis as a measure of goodness of fit, + // see https://github.com/genetics-statistics/GEMMA/issues/81 }; // Results for mvLMM. @@ -118,7 +121,7 @@ public: bool mode_debug = false; uint issue; // enable tests for issue on github tracker - int a_mode; // Analysis mode, 1/2/3/4 for Frequentist tests + uint a_mode; // Analysis mode, 1/2/3/4 for Frequentist tests int k_mode; // Kinship read mode: 1: n by n matrix, 2: id/id/k_value; vector<size_t> p_column; // Which phenotype column needs analysis. size_t d_pace; // Display pace diff --git a/src/prdt.cpp b/src/prdt.cpp index 3e7c004..9dc84bc 100644 --- a/src/prdt.cpp +++ b/src/prdt.cpp @@ -206,6 +206,7 @@ void PRDT::AddBV(gsl_matrix *G, const gsl_vector *u_hat, gsl_vector *y_prdt) { } void PRDT::AnalyzeBimbam(gsl_vector *y_prdt) { + debug_msg("entering"); igzstream infile(file_geno.c_str(), igzstream::in); if (!infile) { cout << "error reading genotype file:" << file_geno << endl; @@ -308,6 +309,7 @@ void PRDT::AnalyzeBimbam(gsl_vector *y_prdt) { } void PRDT::AnalyzePlink(gsl_vector *y_prdt) { + debug_msg("entering"); string file_bed = file_bfile + ".bed"; ifstream infile(file_bed.c_str(), ios::binary); if (!infile) { diff --git a/src/varcov.cpp b/src/varcov.cpp index 0f87ba8..39c3523 100644 --- a/src/varcov.cpp +++ b/src/varcov.cpp @@ -247,6 +247,7 @@ void Calc_Cor(vector<vector<double>> &X_mat, vector<double> &cov_vec) { // genotype file and calculate the covariance matrix for neighboring // SNPs output values at 10000-SNP-interval. void VARCOV::AnalyzeBimbam() { + debug_msg("entering"); igzstream infile(file_geno.c_str(), igzstream::in); if (!infile) { cout << "error reading genotype file:" << file_geno << endl; @@ -345,6 +346,7 @@ void VARCOV::AnalyzeBimbam() { } void VARCOV::AnalyzePlink() { + debug_msg("entering"); string file_bed = file_bfile + ".bed"; ifstream infile(file_bed.c_str(), ios::binary); if (!infile) { diff --git a/src/vc.cpp b/src/vc.cpp index b5f36c0..1465f16 100644 --- a/src/vc.cpp +++ b/src/vc.cpp @@ -407,6 +407,7 @@ int LogRL_dev12(const gsl_vector *log_sigma2, void *params, gsl_vector *dev1, // Read header to determine which column contains which item. bool ReadHeader_vc(const string &line, HEADER &header) { + debug_msg("entering"); string rs_ptr[] = {"rs", "RS", "snp", "SNP", "snps", "SNPS", "snpid", "SNPID", "rsid", "RSID"}; set<string> rs_set(rs_ptr, rs_ptr + 10); @@ -639,6 +640,7 @@ void ReadFile_cor(const string &file_cor, const set<string> &setSnps, vector<double> &vec_cm, vector<double> &vec_bp, map<string, size_t> &mapRS2in, map<string, double> &mapRS2var) { + debug_msg("entering"); vec_rs.clear(); vec_n.clear(); mapRS2in.clear(); @@ -790,6 +792,7 @@ void ReadFile_beta(const bool flag_priorscale, const string &file_beta, map<string, size_t> &mapRS2nsamp, gsl_vector *q_vec, gsl_vector *qvar_vec, gsl_vector *s_vec, size_t &ni_total, size_t &ns_total) { + debug_msg("entering"); mapRS2nsamp.clear(); igzstream infile(file_beta.c_str(), igzstream::in); @@ -1004,6 +1007,7 @@ void ReadFile_cor(const string &file_cor, const vector<string> &vec_rs, const double &window_ns, gsl_matrix *S_mat, gsl_matrix *Svar_mat, gsl_vector *qvar_vec, size_t &ni_total, size_t &ns_total, size_t &ns_test, size_t &ns_pair) { + debug_msg("entering"); igzstream infile(file_cor.c_str(), igzstream::in); if (!infile) { cout << "error! fail to open cov file: " << file_cor << endl; @@ -2213,6 +2217,7 @@ bool BimbamXwz(const string &file_geno, const int display_pace, vector<int> &indicator_idv, vector<int> &indicator_snp, const vector<size_t> &vec_cat, const gsl_vector *w, const gsl_vector *z, size_t ns_test, gsl_matrix *XWz) { + debug_msg("entering"); igzstream infile(file_geno.c_str(), igzstream::in); if (!infile) { cout << "error reading genotype file:" << file_geno << endl; @@ -2306,6 +2311,7 @@ bool PlinkXwz(const string &file_bed, const int display_pace, vector<int> &indicator_idv, vector<int> &indicator_snp, const vector<size_t> &vec_cat, const gsl_vector *w, const gsl_vector *z, size_t ns_test, gsl_matrix *XWz) { + debug_msg("entering"); ifstream infile(file_bed.c_str(), ios::binary); if (!infile) { cout << "error reading bed file:" << file_bed << endl; @@ -2432,6 +2438,7 @@ bool MFILEXwz(const size_t mfile_mode, const string &file_mfile, vector<vector<int>> &mindicator_snp, const vector<size_t> &vec_cat, const gsl_vector *w, const gsl_vector *z, gsl_matrix *XWz) { + debug_msg("entering"); gsl_matrix_set_zero(XWz); igzstream infile(file_mfile.c_str(), igzstream::in); @@ -2466,6 +2473,7 @@ bool MFILEXwz(const size_t mfile_mode, const string &file_mfile, bool BimbamXtXwz(const string &file_geno, const int display_pace, vector<int> &indicator_idv, vector<int> &indicator_snp, const gsl_matrix *XWz, size_t ns_test, gsl_matrix *XtXWz) { + debug_msg("entering"); igzstream infile(file_geno.c_str(), igzstream::in); if (!infile) { cout << "error reading genotype file:" << file_geno << endl; @@ -2556,6 +2564,7 @@ bool BimbamXtXwz(const string &file_geno, const int display_pace, bool PlinkXtXwz(const string &file_bed, const int display_pace, vector<int> &indicator_idv, vector<int> &indicator_snp, const gsl_matrix *XWz, size_t ns_test, gsl_matrix *XtXWz) { + debug_msg("entering"); ifstream infile(file_bed.c_str(), ios::binary); if (!infile) { cout << "error reading bed file:" << file_bed << endl; @@ -2679,6 +2688,7 @@ bool MFILEXtXwz(const size_t mfile_mode, const string &file_mfile, const int display_pace, vector<int> &indicator_idv, vector<vector<int>> &mindicator_snp, const gsl_matrix *XWz, gsl_matrix *XtXWz) { + debug_msg("entering"); gsl_matrix_set_zero(XtXWz); igzstream infile(file_mfile.c_str(), igzstream::in); diff --git a/test/dev_test_suite.sh b/test/dev_test_suite.sh index 9e49251..0fc4423 100755 --- a/test/dev_test_suite.sh +++ b/test/dev_test_suite.sh @@ -2,7 +2,6 @@ gemma=../bin/gemma - # Related to https://github.com/genetics-statistics/GEMMA/issues/78 testBXDStandardRelatednessMatrixKSingularError() { outn=BXDerr @@ -32,7 +31,8 @@ testBXDStandardRelatednessMatrixK() { assertEquals "-116.11" `perl -nle 'foreach $x (split(/\s+/,$_)) { $sum += sprintf("%.2f",(substr($x,,0,6))) } END { printf "%.2f",$sum }' $outfn` } -testBXDMultivariateLinearMixedModel() { +testBXDLMMLikelihoodRatio() { + outn=BXD_LMM_LR $gemma -g ../example/BXD_geno.txt.gz \ -p ../example/BXD_pheno.txt \ -c ../example/BXD_covariates2.txt \ @@ -40,12 +40,12 @@ testBXDMultivariateLinearMixedModel() { -k ./output/BXD.cXX.txt \ -lmm 2 -maf 0.1 \ -debug \ - -o BXD_mvlmm + -o $outn assertEquals 0 $? - outfn=output/BXD_mvlmm.assoc.txt - assertEquals "65862" `wc -w < $outfn` - assertEquals "3088489421.94" `perl -nle 'foreach $x (split(/\s+/,$_)) { $sum += sprintf("%.2f",(substr($x,,0,6))) } END { printf "%.2f",$sum }' $outfn` + outfn=output/$outn.assoc.txt + assertEquals "80498" `wc -w < $outfn` + assertEquals "3088458212.93" `perl -nle 'foreach $x (split(/\s+/,$_)) { $sum += sprintf("%.2f",(substr($x,,0,6))) } END { printf "%.2f",$sum }' $outfn` } testCenteredRelatednessMatrixKLOCO1() { @@ -65,10 +65,12 @@ testCenteredRelatednessMatrixKLOCO1() { testUnivariateLinearMixedModelLOCO1() { outn=mouse_hs1940_CD8_LOCO1_lmm rm -f output/$outn.* - $gemma -g ../example/mouse_hs1940.geno.txt.gz -p ../example/mouse_hs1940.pheno.txt \ + $gemma -g ../example/mouse_hs1940.geno.txt.gz \ + -p ../example/mouse_hs1940.pheno.txt \ -n 1 \ -loco 1 \ - -a ../example/mouse_hs1940.anno.txt -k ./output/mouse_hs1940_LOCO1.cXX.txt \ + -a ../example/mouse_hs1940.anno.txt \ + -k ./output/mouse_hs1940_LOCO1.cXX.txt \ -snps ../example/mouse_hs1940_snps.txt -lmm \ -nind 400 \ -debug \ @@ -78,7 +80,7 @@ testUnivariateLinearMixedModelLOCO1() { assertEquals 0 $? outfn=output/$outn.assoc.txt assertEquals "68" `wc -l < $outfn` - assertEquals "15465553.30" `perl -nle 'foreach $x (split(/\s+/,$_)) { $sum += sprintf("%.2f",(substr($x,,0,6))) } END { printf "%.2f",$sum }' $outfn` + assertEquals "15465346.22" `perl -nle 'foreach $x (split(/\s+/,$_)) { $sum += sprintf("%.2f",(substr($x,,0,6))) } END { printf "%.2f",$sum }' $outfn` } shunit2=`which shunit2` diff --git a/test/lengthy_test_suite.sh b/test/lengthy_test_suite.sh new file mode 100755 index 0000000..231475e --- /dev/null +++ b/test/lengthy_test_suite.sh @@ -0,0 +1,55 @@ +#!/usr/bin/env bash +# +# Long running tests go here + +gemma=../bin/gemma + +testPlinkStandardRelatednessMatrixK() { + testname=testPlinkStandardRelatednessMatrixK + datadir=../example + outfn=output/$testname.sXX.txt + rm -f $outfn + $gemma -bfile $datadir/HLC \ + -gk 2 -o $testname \ + -debug + assertEquals 0 $? + assertEquals "427" `wc -l < $outfn` + assertEquals "-358.07" `perl -nle 'foreach $x (split(/\s+/,$_)) { $sum += sprintf("%.2f",(substr($x,,0,6))) } END { printf "%.2f",$sum }' $outfn` +} + +testPlinkMultivariateLinearMixedModelMultiplePhenotypes_Issue58() { + echo "Long running test!" + # This test passes, but takes over 30 minutes to run! + # n=2 is original pheno in fam file + # n=1 is causal1 + # n=3..12 is causal2 + # n=13..22 is causal3 + # -n 1 2 3 15 is independent + testname=testPlinkMultivariateLinearMixedModelMultiplePhenotypes + datadir=../example + $gemma -bfile $datadir/HLC \ + -p $datadir/HLC.simu.pheno.txt \ + -k output/testPlinkStandardRelatednessMatrixK.sXX.txt \ + -lmm 1 \ + -maf 0.1 \ + -n 1 2 3 15 \ + -c $datadir/HLC_covariates.txt \ + -debug \ + -o $testname + assertEquals 0 $? + outfn=output/$testname.assoc.txt + assertEquals "223243" `wc -l < $outfn` + assertEquals "89754977983.69" `perl -nle 'foreach $x (split(/\s+/,$_)) { $sum += sprintf("%.2f",(substr($x,,0,6))) } END { printf "%.2f",$sum }' $outfn` +} + +shunit2=`which shunit2` + +if [ -x "$shunit2" ]; then + echo run system shunit2 + . $shunit2 +elif [ -e ../contrib/shunit2-2.0.3/src/shell/shunit2 ]; then + echo run shunit2 provided in gemma repo + . ../contrib/shunit2-2.0.3/src/shell/shunit2 +else + echo "Can not find shunit2 - see INSTALL.md" +fi diff --git a/test/test_suite.sh b/test/test_suite.sh index 44eb14c..350fc27 100755 --- a/test/test_suite.sh +++ b/test/test_suite.sh @@ -30,13 +30,13 @@ testUnivariateLinearMixedModelFullLOCO1() { assertEquals 0 $? outfn=output/$outn.assoc.txt assertEquals "951" `wc -l < $outfn` - assertEquals "267509369.79" `perl -nle 'foreach $x (split(/\s+/,$_)) { $sum += sprintf("%.2f",(substr($x,,0,6))) } END { printf "%.2f",$sum }' $outfn` + assertEquals "267507851.98" `perl -nle 'foreach $x (split(/\s+/,$_)) { $sum += sprintf("%.2f",(substr($x,,0,6))) } END { printf "%.2f",$sum }' $outfn` } testCenteredRelatednessMatrixK() { $gemma -g ../example/mouse_hs1940.geno.txt.gz \ -p ../example/mouse_hs1940.pheno.txt \ - -gk -o mouse_hs1940 + -gk -o mouse_hs1940 -debug assertEquals 0 $? outfn=output/mouse_hs1940.cXX.txt assertEquals "1940" `wc -l < $outfn` @@ -52,13 +52,14 @@ testUnivariateLinearMixedModel() { -a ../example/mouse_hs1940.anno.txt \ -k ./output/mouse_hs1940.cXX.txt \ -lmm \ - -o mouse_hs1940_CD8_lmm + -o mouse_hs1940_CD8_lmm \ + -debug assertEquals 0 $? grep "total computation time" < output/mouse_hs1940_CD8_lmm.log.txt assertEquals 0 $? outfn=output/mouse_hs1940_CD8_lmm.assoc.txt - assertEquals "118459" `wc -w < $outfn` - assertEquals "4038557453.62" `perl -nle 'foreach $x (split(/\s+/,$_)) { $sum += sprintf("%.2f",(substr($x,,0,6))) } END { printf "%.2f",$sum }' $outfn` + assertEquals "129228" `wc -w < $outfn` + assertEquals "4038540440.86" `perl -nle 'foreach $x (split(/\s+/,$_)) { $sum += sprintf("%.2f",(substr($x,,0,6))) } END { printf "%.2f",$sum }' $outfn` } testMultivariateLinearMixedModel() { @@ -67,7 +68,8 @@ testMultivariateLinearMixedModel() { -n 1 6 \ -a ../example/mouse_hs1940.anno.txt \ -k ./output/mouse_hs1940.cXX.txt \ - -lmm -o mouse_hs1940_CD8MCH_lmm + -lmm -o mouse_hs1940_CD8MCH_lmm \ + -debug assertEquals 0 $? outfn=output/mouse_hs1940_CD8MCH_lmm.assoc.txt @@ -81,7 +83,8 @@ testPlinkStandardRelatednessMatrixK() { outfn=output/$testname.sXX.txt rm -f $outfn $gemma -bfile $datadir/HLC \ - -gk 2 -o $testname + -gk 2 -o $testname \ + -debug assertEquals 0 $? assertEquals "427" `wc -l < $outfn` assertEquals "-358.07" `perl -nle 'foreach $x (split(/\s+/,$_)) { $sum += sprintf("%.2f",(substr($x,,0,6))) } END { printf "%.2f",$sum }' $outfn` @@ -97,11 +100,12 @@ testPlinkMultivariateLinearMixedModel() { -lmm 1 \ -maf 0.1 \ -c $datadir/HLC_covariates.txt \ + -debug \ -o $testname assertEquals 0 $? outfn=output/$testname.assoc.txt assertEquals "223243" `wc -l < $outfn` - assertEquals "89756559859.06" `perl -nle 'foreach $x (split(/\s+/,$_)) { $sum += sprintf("%.2f",(substr($x,,0,6))) } END { printf "%.2f",$sum }' $outfn` + assertEquals "89757159113.77" `perl -nle 'foreach $x (split(/\s+/,$_)) { $sum += sprintf("%.2f",(substr($x,,0,6))) } END { printf "%.2f",$sum }' $outfn` } shunit2=`which shunit2` |