{"id":268743,"date":"2015-11-23T09:49:02","date_gmt":"2015-11-23T06:49:02","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=268743"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=268743","title":{"rendered":"\u0413\u0440\u0430\u0432\u0438\u0442\u0430\u0446\u0438\u043e\u043d\u043d\u043e\u0435 \u043f\u043e\u043b\u0435 \u043d\u0430 \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u0438 \u0442\u0435\u043b \u043d\u0435\u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e\u0439 \u0444\u043e\u0440\u043c\u044b \u043d\u0430 \u043f\u0440\u0438\u043c\u0435\u0440\u0435 \u043a\u043e\u043c\u0435\u0442\u044b \u0427\u0443\u0440\u044e\u043c\u043e\u0432\u0430-\u0413\u0435\u0440\u0430\u0441\u0438\u043c\u0435\u043d\u043a\u043e"},"content":{"rendered":"<p>       \u0418\u0437 \u0437\u0430\u043a\u043e\u043d\u0430 \u0432\u0441\u0435\u043c\u0438\u0440\u043d\u043e\u0433\u043e \u0442\u044f\u0433\u043e\u0442\u0435\u043d\u0438\u044f \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u043e, \u0447\u0442\u043e \u043d\u0430 \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u0438 \u0442\u0435\u043b \u0448\u0430\u0440\u043e\u043e\u0431\u0440\u0430\u0437\u043d\u043e\u0439 \u0444\u043e\u0440\u043c\u044b \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u0435 \u0441\u0432\u043e\u0431\u043e\u0434\u043d\u043e\u0433\u043e \u043f\u0430\u0434\u0435\u043d\u0438\u044f \u043f\u043e\u0441\u0442\u043e\u044f\u043d\u043d\u043e \u043f\u043e \u043c\u043e\u0434\u0443\u043b\u044e \u0438 \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043e \u043a \u0446\u0435\u043d\u0442\u0440\u0443 \u0448\u0430\u0440\u0430. \u0414\u043b\u044f \u0442\u0435\u043b \u043d\u0435\u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e\u0439 \u0444\u043e\u0440\u043c\u044b \u044d\u0442\u043e \u043f\u0440\u0430\u0432\u0438\u043b\u043e, \u043e\u0447\u0435\u0432\u0438\u0434\u043d\u043e, \u043d\u0435 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442\u0441\u044f. \u0412 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u044f \u043f\u043e\u043a\u0430\u0436\u0443 \u0441\u043f\u043e\u0441\u043e\u0431 \u0440\u0430\u0441\u0447\u0451\u0442\u0430 \u0438 \u0432\u0438\u0437\u0443\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u044f \u0441\u0432\u043e\u0431\u043e\u0434\u043d\u043e\u0433\u043e \u043f\u0430\u0434\u0435\u043d\u0438\u044f \u0434\u043b\u044f \u0442\u0430\u043a\u0438\u0445 \u0442\u0435\u043b. \u0420\u0430\u0441\u0447\u0451\u0442 \u0431\u0443\u0434\u0435\u043c \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u044c \u043d\u0430 JavaScript, \u0432\u0438\u0437\u0443\u0430\u043b\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u2014 \u043d\u0430 WebGL \u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435\u043c \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 <a href=\"http:\/\/threejs.org\">three.js<\/a>.<\/p>\n<p>  \u0412 \u0438\u0442\u043e\u0433\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u043c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435 (\u043a\u0440\u0430\u0441\u043d\u044b\u043c \u0446\u0432\u0435\u0442\u043e\u043c \u043e\u0442\u043c\u0435\u0447\u0435\u043d\u044b \u043e\u0431\u043b\u0430\u0441\u0442\u0438 \u0441 \u0431\u043e\u043b\u044c\u0448\u0438\u043c \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u0435\u043c \u0441\u0432\u043e\u0431\u043e\u0434\u043d\u043e\u0433\u043e \u043f\u0430\u0434\u0435\u043d\u0438\u044f, \u0441\u0438\u043d\u0438\u043c \u2014 \u0441 \u043c\u0430\u043b\u044b\u043c):<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/files\/2eb\/f0b\/258\/2ebf0b258ec644a792a1f9295b22d5bb.png\"\/><br \/>  <a name=\"habracut\"><\/a>  <\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u0413\u0438\u0444\u043a\u0430<\/b><\/p>\n<div class=\"spoiler_text\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/files\/4e6\/a20\/839\/4e6a208396eb4e4488064d5298b2cb02.gif\"\/><\/p>\n<p>  \u041e\u0441\u044c \u0432\u0440\u0430\u0449\u0435\u043d\u0438\u044f \u043d\u0430 \u0433\u0438\u0444\u043a\u0435 \u0443\u0441\u043b\u043e\u0432\u043d\u0430\u044f. \u041e\u043d\u0430 \u043d\u0435 \u0441\u043e\u0432\u043f\u0430\u0434\u0430\u0435\u0442 \u0441 \u043e\u0441\u044c\u044e \u0432\u0440\u0430\u0449\u0435\u043d\u0438\u044f \u043a\u043e\u043c\u0435\u0442\u044b.  <\/div>\n<\/div>\n<p>  \u0414\u043b\u044f \u0440\u0430\u0441\u0447\u0435\u0442\u043e\u0432 \u0433\u0440\u0430\u0432\u0438\u0442\u0430\u0446\u0438\u043e\u043d\u043d\u043e\u0433\u043e \u043f\u043e\u0442\u0435\u043d\u0446\u0438\u0430\u043b\u0430 \u043f\u043b\u0430\u043d\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0430\u044f <a href=\"https:\/\/ru.wikipedia.org\/wiki\/%D0%93%D1%80%D0%B0%D0%B2%D0%B8%D1%82%D0%B0%D1%86%D0%B8%D0%BE%D0%BD%D0%BD%D1%8B%D0%B9_%D0%BF%D0%BE%D1%82%D0%B5%D0%BD%D1%86%D0%B8%D0%B0%D0%BB#.D0.93.D1.80.D0.B0.D0.B2.D0.B8.D1.82.D0.B0.D1.86.D0.B8.D0.BE.D0.BD.D0.BD.D1.8B.D0.B9_.D0.BF.D0.BE.D1.82.D0.B5.D0.BD.D1.86.D0.B8.D0.B0.D0.BB_.D0.BF.D0.BB.D0.B0.D0.BD.D0.B5.D1.82\">\u0444\u043e\u0440\u043c\u0443\u043b\u0430<\/a>:<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/files\/e43\/d09\/aec\/e43d09aece6e49d2a06e26ec2ea46973.png\"\/><\/p>\n<p>  \u041d\u043e, \u043a \u0441\u043e\u0436\u0430\u043b\u0435\u043d\u0438\u044e, \u043f\u0440\u0438 \u043c\u0430\u043b\u044b\u0445 r \u044d\u0442\u043e\u0442 \u0440\u044f\u0434 \u0441\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u043e, \u0430 \u043f\u0440\u0438 \u043e\u0447\u0435\u043d\u044c \u043c\u0430\u043b\u044b\u0445 r \u0432\u043e\u043e\u0431\u0449\u0435 \u0440\u0430\u0441\u0445\u043e\u0434\u0438\u0442\u0441\u044f. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u0434\u043b\u044f \u0440\u0430\u0441\u0447\u0435\u0442\u0430 \u0433\u0440\u0430\u0432\u0438\u0442\u0430\u0446\u0438\u043e\u043d\u043d\u043e\u0433\u043e \u043f\u043e\u0442\u0435\u043d\u0446\u0438\u0430\u043b\u0430 \u043d\u0430 \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u0438 \u043d\u0435\u0431\u0435\u0441\u043d\u044b\u0445 \u0442\u0435\u043b \u044d\u0442\u0430 \u0444\u043e\u0440\u043c\u0443\u043b\u0430 \u043d\u0435 \u0433\u043e\u0434\u0438\u0442\u0441\u044f. \u0412 \u043e\u0431\u0449\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435, \u043f\u0440\u0438\u0434\u0435\u0442\u0441\u044f \u043f\u0440\u043e\u0432\u0435\u0441\u0442\u0438 \u0438\u043d\u0442\u0435\u0433\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u043f\u043e \u0432\u0441\u0435\u043c\u0443 \u043e\u0431\u044a\u0451\u043c\u0443 \u0442\u0435\u043b\u0430.<br \/>  \u0422\u0440\u0451\u0445\u043c\u0435\u0440\u043d\u043e\u0435 \u0442\u0435\u043b\u043e \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u0432 \u0432\u0438\u0434\u0435 \u043d\u0430\u0431\u043e\u0440\u043e\u0432 \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u044b\u0445 \u0433\u0440\u0430\u043d\u0435\u0439, \u0441 \u0437\u0430\u0434\u0430\u043d\u043d\u044b\u043c\u0438 \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u0430\u043c\u0438 \u0432\u0435\u0440\u0448\u0438\u043d. \u0414\u0430\u043b\u0435\u0435 \u0431\u0443\u0434\u0435\u043c \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u0430\u0433\u0430\u0442\u044c, \u0447\u0442\u043e \u043f\u043b\u043e\u0442\u043d\u043e\u0441\u0442\u044c \u0442\u0435\u043b\u0430 \u043f\u043e\u0441\u0442\u043e\u044f\u043d\u043d\u0430 (\u0434\u043b\u044f \u043a\u043e\u043c\u0435\u0442\u044b \u044d\u0442\u043e \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u0435\u0442 \u0438\u0441\u0442\u0438\u043d\u0435). \u0413\u0440\u0430\u0432\u0438\u0442\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0439 \u043f\u043e\u0442\u0435\u043d\u0446\u0438\u0430\u043b \u0432 \u0437\u0430\u0434\u0430\u043d\u043d\u043e\u0439 \u0442\u043e\u0447\u043a\u0435 \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0432\u0435\u043d \u0441\u0443\u043c\u043c\u0435 \u043f\u043e\u0442\u0435\u043d\u0446\u0438\u0430\u043b\u043e\u0432 \u0432\u0441\u0435\u0445 \u0442\u0435\u0442\u0440\u0430\u044d\u0434\u0440\u043e\u0432, \u0441 \u043e\u0441\u043d\u043e\u0432\u0430\u043d\u0438\u0435\u043c \u0432 \u044d\u0442\u0438\u0445 \u0433\u0440\u0430\u043d\u044f\u0445 \u0438 \u0441 \u0432\u0435\u0440\u0448\u0438\u043d\u043e\u0439 \u0432 \u0437\u0430\u0434\u0430\u043d\u043d\u043e\u0439 \u0442\u043e\u0447\u043a\u0435 (\u043c\u044b \u0438\u0449\u0435\u043c \u043d\u0435 \u0433\u0440\u0430\u0432\u0438\u0442\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0439 \u043f\u043e\u0442\u0435\u043d\u0446\u0438\u0430\u043b, \u0430 \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u0435 \u0441\u0432\u043e\u0431\u043e\u0434\u043d\u043e\u0433\u043e \u043f\u0430\u0434\u0435\u043d\u0438\u044f, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u0435\u0441\u0442\u044c \u0433\u0440\u0430\u0434\u0438\u0435\u043d\u0442 \u043f\u043e\u0442\u0435\u043d\u0446\u0438\u0430\u043b\u0430, \u043d\u043e \u0440\u0430\u0441\u0441\u0443\u0436\u0434\u0435\u043d\u0438\u044f \u043e\u0441\u0442\u0430\u044e\u0442\u0441\u044f \u0442\u0435\u043c\u0438 \u0436\u0435).<\/p>\n<p>  \u0414\u043b\u044f \u043d\u0430\u0447\u0430\u043b\u0430 \u043d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u043d\u0430\u0439\u0442\u0438 \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u0435, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442 \u043c\u0430\u0441\u0441\u0430 \u0442\u0435\u0442\u0440\u0430\u044d\u0434\u0440\u0430 \u043d\u0430 \u0442\u043e\u0447\u043a\u0443, \u043d\u0430\u0445\u043e\u0434\u044f\u0449\u0443\u044e\u0441\u044f \u0432 \u0435\u0433\u043e \u0432\u0435\u0440\u0448\u0438\u043d\u0435. \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043d\u0443\u0436\u043d\u043e \u043f\u0440\u043e\u0438\u0437\u0432\u0435\u0441\u0442\u0438 \u0438\u043d\u0442\u0435\u0433\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u043f\u043e \u0432\u0441\u0435\u043c\u0443 \u043e\u0431\u044a\u0451\u043c\u0443 \u0442\u0435\u0442\u0440\u0430\u044d\u0434\u0440\u0430. \u041a \u0441\u043e\u0436\u0430\u043b\u0435\u043d\u0438\u044e \u0434\u0430\u043d\u043d\u044b\u0439 \u0438\u043d\u0442\u0435\u0433\u0440\u0430\u043b \u043d\u0435 \u0431\u0435\u0440\u0451\u0442\u0441\u044f \u0432 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u0440\u043d\u044b\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u044f\u0445, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043f\u0440\u0438\u0434\u0451\u0442\u0441\u044f \u043f\u043e\u0439\u0442\u0438 \u043d\u0430 \u0445\u0438\u0442\u0440\u043e\u0441\u0442\u044c.<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/files\/25e\/add\/63a\/25eadd63a1f34b56a4f9d6149fcfd557.png\"\/><\/p>\n<p>  \u0421\u0438\u043b\u0430, \u0434\u0435\u0439\u0441\u0442\u0432\u0443\u044e\u0449\u0430\u044f \u043d\u0430 \u0442\u043e\u0447\u043a\u0443 \u0432 \u0432\u0435\u0440\u0448\u0438\u043d\u0435 \u0442\u0435\u0442\u0440\u0430\u044d\u0434\u0440\u0430 \u043f\u0440\u0438\u0431\u043b\u0438\u0437\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0432 \u0442\u0440\u0438 \u0440\u0430\u0437\u0430 \u0431\u043e\u043b\u044c\u0448\u0435, \u0447\u0435\u043c \u0441\u0438\u043b\u0430, \u0432\u044b\u0437\u0432\u0430\u043d\u043d\u0430\u044f \u0433\u0440\u0430\u0432\u0438\u0442\u0430\u0446\u0438\u0435\u0439 \u0448\u0430\u0440\u0430, \u043f\u043e\u043c\u0435\u0449\u0435\u043d\u043d\u043e\u0433\u043e \u0432 \u0441\u0435\u0440\u0435\u0434\u0438\u043d\u0443 \u043e\u0441\u043d\u043e\u0432\u0430\u043d\u0438\u044f \u0442\u0435\u0442\u0440\u0430\u044d\u0434\u0440\u0430 (\u043c\u0430\u0441\u0441\u0430 \u0448\u0430\u0440\u0430 \u043f\u0440\u0438 \u044d\u0442\u043e\u043c \u0440\u0430\u0432\u043d\u0430 \u043c\u0430\u0441\u0441\u0435 \u0442\u0435\u0442\u0440\u0430\u044d\u0434\u0440\u0430). \u0422. \u0435. F<sub>1<\/sub>\u22483*F<sub>2<\/sub>. \u042d\u0442\u043e \u0440\u0430\u0432\u0435\u043d\u0441\u0442\u0432\u043e \u043b\u0443\u0447\u0448\u0435 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442\u0441\u044f \u043f\u0440\u0438 \u043c\u0430\u043b\u043e\u043c \u0443\u0433\u043b\u0435 \u0440\u0430\u0441\u0442\u0432\u043e\u0440\u0430 \u0442\u0435\u0442\u0440\u0430\u044d\u0434\u0440\u0430. \u0414\u043b\u044f \u043e\u0446\u0435\u043d\u043a\u0438 \u0432\u0435\u043b\u0438\u0447\u0438\u043d\u044b \u043e\u0442\u043a\u043b\u043e\u043d\u0435\u043d\u0438\u044f \u0440\u0430\u0432\u0435\u043d\u0441\u0442\u0432\u0430 \u043e\u0442 \u0441\u0442\u0440\u043e\u0433\u043e\u0433\u043e, \u044f \u0441\u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u043b \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0442\u044b\u0441\u044f\u0447 \u0440\u0430\u043d\u0434\u043e\u043c\u043d\u044b\u0445 \u0442\u0435\u0442\u0440\u0430\u044d\u0434\u0440\u043e\u0432 \u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u0438\u043b \u0434\u043b\u044f \u043d\u0438\u0445 \u044d\u0442\u0443 \u0432\u0435\u043b\u0438\u0447\u0438\u043d\u0443.<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/files\/e75\/714\/a4f\/e75714a4f46f4e72bd4a5d5d2ed4b2de.png\"\/><\/p>\n<p>  \u041d\u0430 \u0433\u0440\u0430\u0444\u0438\u043a\u0435 \u043f\u043e \u043e\u0441\u0438 \u0430\u0431\u0441\u0446\u0438\u0441\u0441 \u043f\u043e\u043a\u0430\u0437\u0430\u043d\u043e \u043e\u0442\u043d\u043e\u0448\u0435\u043d\u0438\u0435 \u043f\u0435\u0440\u0438\u043c\u0435\u0442\u0440\u0430 \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u043e\u0433\u043e \u043e\u0441\u043d\u043e\u0432\u0430\u043d\u0438\u044f \u043a \u0440\u0430\u0441\u0441\u0442\u043e\u044f\u043d\u0438\u044e \u043e\u0442 \u0432\u0435\u0440\u0448\u0438\u043d\u044b \u0434\u043e \u0446\u0435\u043d\u0442\u0440\u0430 \u043e\u0441\u043d\u043e\u0432\u0430\u043d\u0438\u044f. \u041f\u043e \u043e\u0441\u0438 \u043e\u0440\u0434\u0438\u043d\u0430\u0442 \u2014 \u0432\u0435\u043b\u0438\u0447\u0438\u043d\u0430 \u043e\u0448\u0438\u0431\u043a\u0438. \u041a\u0430\u043a \u0432\u0438\u0434\u043d\u043e, \u0432\u0435\u043b\u0438\u0447\u0438\u043d\u0443 \u043e\u0448\u0438\u0431\u043a\u0438 \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u043a\u0432\u0430\u0434\u0440\u0430\u0442\u0438\u0447\u043d\u043e\u0439 \u0444\u0443\u043d\u043a\u0446\u0438\u0435\u0439. \u0417\u0430 \u0440\u0435\u0434\u043a\u0438\u043c \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435\u043c \u0432\u0441\u0435 \u0442\u043e\u0447\u043a\u0438 \u043d\u0430\u0445\u043e\u0434\u044f\u0442\u0441\u044f \u043d\u0438\u0436\u0435 \u043f\u0430\u0440\u0430\u0431\u043e\u043b\u044b (\u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u043d\u0430\u043c \u043f\u043e\u0433\u043e\u0434\u0443 \u043e\u0441\u043e\u0431\u043e \u043d\u0435 \u0438\u0441\u043f\u043e\u0440\u0442\u044f\u0442).<\/p>\n<p>  \u0412\u0435\u043b\u0438\u0447\u0438\u043d\u0443 \u0433\u0440\u0430\u0432\u0438\u0442\u0430\u0446\u0438\u043e\u043d\u043d\u043e\u0433\u043e \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u044f \u0431\u0443\u0434\u0435\u043c \u0432\u044b\u0447\u0438\u0441\u043b\u044f\u0442\u044c \u0441 \u0437\u0430\u0434\u0430\u043d\u043d\u043e\u0439 \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0439 \u043f\u043e\u0433\u0440\u0435\u0448\u043d\u043e\u0441\u0442\u044c\u044e. \u0415\u0441\u043b\u0438 \u043e\u0448\u0438\u0431\u043a\u0430 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u043f\u0440\u0435\u0432\u044b\u0448\u0430\u0435\u0442 \u044d\u0442\u0443 \u043f\u043e\u0433\u0440\u0435\u0448\u043d\u043e\u0441\u0442\u044c, \u0442\u043e \u0440\u0430\u0437\u0431\u0438\u0432\u0430\u0435\u043c \u043d\u0430\u0448 \u0442\u0435\u0442\u0440\u0430\u044d\u0434\u0440 \u043d\u0430 \u0447\u0435\u0442\u044b\u0440\u0435 \u0447\u0430\u0441\u0442\u0438 \u043f\u043e \u043e\u0441\u043d\u043e\u0432\u0430\u043d\u0438\u044e \u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u044f\u0435\u043c \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u0435 \u0434\u043b\u044f \u044d\u0442\u0438\u0445 \u0447\u0430\u0441\u0442\u0435\u0439 \u043f\u043e \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438, \u0437\u0430\u0442\u0435\u043c \u0441\u0443\u043c\u043c\u0438\u0440\u0443\u0435\u043c.<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/files\/835\/f97\/48a\/835f9748a67c425d9bba0c6b7dab64ae.png\"\/><\/p>\n<p>  \u0423\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u0435 \u043c\u044b \u043d\u0430\u0445\u043e\u0434\u0438\u043c \u0441 \u0442\u043e\u0447\u043d\u043e\u0441\u0442\u044c\u044e \u0434\u043e \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u043f\u043e\u0441\u0442\u043e\u044f\u043d\u043d\u043e\u0433\u043e, \u0434\u043b\u044f \u0434\u0430\u043d\u043d\u043e\u0433\u043e \u0442\u0435\u043b\u0430, \u043a\u043e\u044d\u0444\u0444\u0438\u0446\u0438\u0435\u043d\u0442\u0430, \u0437\u0430\u0432\u0438\u0441\u044f\u0449\u0435\u0433\u043e \u043e\u0442 \u043c\u0430\u0441\u0441\u044b (\u0438\u043b\u0438 \u043f\u043b\u043e\u0442\u043d\u043e\u0441\u0442\u0438) \u0442\u0435\u043b\u0430, \u0433\u0440\u0430\u0432\u0438\u0442\u0430\u0446\u0438\u043e\u043d\u043d\u043e\u0439 \u043f\u043e\u0441\u0442\u043e\u044f\u043d\u043d\u043e\u0439 \u0438 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0434\u0440\u0443\u0433\u0438\u0445 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432. \u042d\u0442\u043e\u0442 \u043a\u043e\u044d\u0444\u0444\u0438\u0446\u0438\u0435\u043d\u0442 \u043c\u044b \u0443\u0447\u0442\u0451\u043c \u043f\u043e\u0437\u0436\u0435.<\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u041f\u0440\u0438\u0448\u043b\u043e \u0432\u0440\u0435\u043c\u044f \u043a\u043e\u0434\u0430<\/b><\/p>\n<div class=\"spoiler_text\">\n<pre><code class=\"javascript\">function force_pyramide(p1, p2, p3, rel) { \t\/\/ \u043d\u0430\u0447\u0430\u043b\u044c\u043d\u0430\u044f \u0442\u043e\u0447\u043a\u0430 \u0432 (0, 0, 0) \t\/\/ rel - \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u0430\u044f \u043f\u043e\u0433\u0440\u0435\u0448\u043d\u043e\u0441\u0442\u044c \tvar volume = (1\/6) * triple_product(p1, p2, p3); \/\/ \u043e\u0431\u044a\u0451\u043c \u0442\u0435\u0442\u0440\u0430\u044d\u0434\u0440\u0430 \tif (volume == 0) \t\treturn new vector3(0, 0, 0); \tif (!rel) \t\trel = 0.01; \tvar p0 = middleVector(p1, p2, p3); \/\/ \u0432\u0435\u043a\u0442\u043e\u0440 \u0446\u0435\u043d\u0442\u0440\u0430 \u043e\u0441\u043d\u043e\u0432\u0430\u043d\u0438\u044f \tvar len = p0.length(); \tvar per = perimeter(p1, p2, p3); \/\/ \u043f\u0435\u0440\u0438\u043c\u0435\u0442\u0440 \u043e\u0441\u043d\u043e\u0432\u0430\u043d\u0438\u044f \tvar tan_per = per \/ len; \tvar error = 0.015 * sqr(tan_per); \/\/ \u0442\u0430 \u0441\u0430\u043c\u0430\u044f \u044d\u043c\u043f\u0438\u0440\u0438\u0447\u0435\u0441\u043a\u0430\u044f \u043a\u0432\u0430\u0434\u0440\u0430\u0442\u0438\u0447\u043d\u0430\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u044f \tif (error &gt; rel) { \t\tvar p12 = middleVector(p1, p2); \t\tvar p13 = middleVector(p1, p3); \t\tvar p23 = middleVector(p2, p3); \t\treturn sumVector( \t\t\tforce_pyramide(p1, p12, p13, rel), \t\t\tforce_pyramide(p2, p23, p12, rel), \t\t\tforce_pyramide(p3, p13, p23, rel), \t\t\tforce_pyramide(p12, p23, p13, rel) \t\t); \t} \tvar ratio = 3 * volume * Math.pow(len, -3); \treturn new vector3(p0.x, p0.y, p0.z).multiplyScalar(ratio); } <\/code><\/pre>\n<p>  <\/div>\n<\/div>\n<p>  \u0412\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0435 \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u044f \u043e\u0442 \u0442\u0440\u0451\u0445\u043c\u0435\u0440\u043d\u043e\u0433\u043e \u0442\u0435\u043b\u0430 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u043c \u0441\u0443\u043c\u043c\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435\u043c \u043f\u043e \u0432\u0441\u0435\u043c \u0442\u0435\u0442\u0440\u0430\u044d\u0434\u0440\u0430\u043c, \u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u043d\u044b\u043c \u0433\u0440\u0430\u043d\u044f\u043c\u0438 \u0442\u0435\u043b\u0430 \u0438 \u0437\u0430\u0434\u0430\u043d\u043d\u043e\u0439 \u0442\u043e\u0447\u043a\u043e\u0439 (\u043e \u0447\u0451\u043c \u044f \u043f\u0438\u0441\u0430\u043b \u0440\u0430\u043d\u0435\u0435).<\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u0421\u043a\u0440\u044b\u0442\u044b\u0439 \u0442\u0435\u043a\u0441\u0442<\/b><\/p>\n<div class=\"spoiler_text\">\n<pre><code class=\"javascript\">function force_object(p0, obj, rel) { \tvar result = new vector3(0, 0, 0); \tfor (var i = 0; i &lt; obj.faces.length; i++) { \t\tp1 = subVectors(obj.vertices[obj.faces[i][0] - 1], p0); \t\tp2 = subVectors(obj.vertices[obj.faces[i][1] - 1], p0); \t\tp3 = subVectors(obj.vertices[obj.faces[i][2] - 1], p0); \t\tvar f = force_pyramide(p1, p2, p3, rel); \t\tresult = addVectors(result, f); \t} \treturn result; } <\/code><\/pre>\n<p>  <\/div>\n<\/div>\n<p>  \u0412\u044b\u0447\u0438\u0441\u043b\u044f\u0435\u043c \u0433\u0440\u0430\u0432\u0438\u0442\u0430\u0446\u0438\u043e\u043d\u043d\u043e\u0435 \u0438 \u0446\u0435\u043d\u0442\u0440\u043e\u0431\u0435\u0436\u043d\u043e\u0435 \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u044f \u043d\u0430 \u043a\u043e\u043c\u0435\u0442\u0435 (\u0432\u0440\u0430\u0449\u0435\u043d\u0438\u0435 \u043a\u043e\u043c\u0435\u0442\u044b \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442 \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u0435 \u043f\u043e\u0440\u044f\u0434\u043a\u0430 25% \u043e\u0442 \u0433\u0440\u0430\u0432\u0438\u0442\u0430\u0446\u0438\u043e\u043d\u043d\u043e\u0433\u043e, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043f\u0440\u0435\u043d\u0435\u0431\u0440\u0435\u0433\u0430\u0442\u044c \u0438\u043c \u043d\u0435\u043b\u044c\u0437\u044f). \u041e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u0443\u044e \u043f\u043e\u0433\u0440\u0435\u0448\u043d\u043e\u0441\u0442\u044c \u044f \u0432\u044b\u0441\u0442\u0430\u0432\u0438\u043b \u0432 0,01. \u041a\u0430\u0437\u0430\u043b\u043e\u0441\u044c \u0431\u044b \u044d\u0442\u043e \u043c\u043d\u043e\u0433\u043e, \u043d\u043e \u043f\u043e \u0444\u0430\u043a\u0442\u0443 \u043f\u0440\u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0438 \u043f\u043e\u0433\u0440\u0435\u0448\u043d\u043e\u0441\u0442\u044c \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f \u0440\u0430\u0437\u0430 \u0432 \u0442\u0440\u0438 \u043c\u0435\u043d\u044c\u0448\u0435 \u0438 \u043f\u0440\u0438 \u0432\u0438\u0437\u0443\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0440\u0430\u0437\u043d\u0438\u0446\u0430 \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u043e \u043d\u0435 \u0437\u0430\u043c\u0435\u0442\u043d\u0430 (\u0442. \u043a. \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u0430\u044f \u0440\u0430\u0437\u043d\u0438\u0446\u0430 \u0432 \u0446\u0432\u0435\u0442\u0435 \u043f\u0438\u043a\u0441\u0435\u043b\u0435\u0439 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 1\/256\u22480,004). \u0410 \u0435\u0441\u043b\u0438 \u0432\u044b\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u043f\u043e\u0433\u0440\u0435\u0448\u043d\u043e\u0441\u0442\u044c \u043c\u0435\u043d\u044c\u0448\u0435, \u0442\u043e \u0432\u0440\u0435\u043c\u044f \u0440\u0430\u0441\u0447\u0451\u0442\u0430 \u0443\u0432\u0435\u043b\u0438\u0447\u0438\u0432\u0430\u0435\u0442\u0441\u044f.<\/p>\n<p>  \u041f\u0440\u0438 \u043f\u043e\u0433\u0440\u0435\u0448\u043d\u043e\u0441\u0442\u0438, \u0440\u0430\u0432\u043d\u043e\u0439 0,01, \u0440\u0430\u0441\u0447\u0451\u0442 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442\u0441\u044f 1-2 \u0441\u0435\u043a\u0443\u043d\u0434\u044b, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043e\u0444\u043e\u0440\u043c\u043b\u044f\u0435\u043c \u0435\u0433\u043e \u0447\u0435\u0440\u0435\u0437 setInterval, \u0432\u043e \u0438\u0437\u0431\u0435\u0436\u0430\u043d\u0438\u0435 \u043f\u043e\u0434\u0432\u0438\u0441\u0430\u043d\u0438\u044f \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430.<\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u041a\u043e\u0434<\/b><\/p>\n<div class=\"spoiler_text\">\n<pre><code class=\"javascript\">var rel = 0.01; \/\/ \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u0430\u044f \u043f\u043e\u0433\u0440\u0435\u0448\u043d\u043e\u0441\u0442\u044c var scale = 1000; \/\/ \u043c\u043e\u0434\u0435\u043b\u044c \u0437\u0430\u0434\u0430\u043d\u0430 \u0432 \u043a\u0438\u043b\u043e\u043c\u0435\u0442\u0440\u0430\u0445, \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0438\u043c \u0432 \u043c\u0435\u0442\u0440\u044b var grav_ratio = 6.672e-11 * 1.0e+13 \/ (sqr(scale) * volume); \/\/ \u043c\u0430\u0441\u0441\u0430 \u043a\u043e\u043c\u0435\u0442\u044b 1\u0435+13 \u043a\u0433 var omega2 = sqr(2 * Math.PI \/ (12.4 * 3600)); \/\/ \u043f\u0435\u0440\u0438\u043e\u0434 \u0432\u0440\u0430\u0449\u0435\u043d\u0438\u044f \u043a\u043e\u043c\u0435\u0442\u044b 12,4 \u0447\u0430\u0441\u043e\u0432  function computeGrav() { \tinfo.innerHTML = '\u0420\u0430\u0441\u0447\u0451\u0442: ' + (100 * item \/ object3d.vertices.length).toFixed() + '%'; \tfor (var i = 0; i &lt; 50; i++) { \t\tvar p0 = object3d.vertices[item]; \t\tgrav_force[item] = force_object(p0, object3d, rel).multiplyScalar(grav_ratio); \t\t\/\/ \u0433\u0440\u0430\u0432\u0438\u0442\u0430\u0446\u0438\u043e\u043d\u043d\u043e\u0435 \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u0435 \t\tcircular_force[item] = new vector3(omega2 * p0.x * scale, omega2 * p0.y * scale, 0); \t\t\/\/ \u0446\u0435\u043d\u0442\u0440\u043e\u0431\u0435\u0436\u043d\u043e\u0435 \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u0435, \u043e\u0441\u044c \u0432\u0440\u0430\u0449\u0435\u043d\u0438\u044f \u0441\u043e\u0432\u043f\u0430\u0434\u0430\u0435\u0442 \u0441 \u043e\u0441\u044c\u044e z \t\tabs_grav_force[item] = grav_force[item].length(); \t\tabs_circular_force[item] = circular_force[item].length(); \t\titem++; \t\tif (item &gt;= object3d.vertices.length) { \t\t\tconsole.timeEnd('gravity calculate'); \t\t\tclearInterval(timerId); \t\t\taccelSelect(); \t\t\tinit(); \t\t\tanimate(); \t\t\tbreak; \t\t} \t} }  var item = 0; console.time('gravity calculate'); var timerId = setInterval(computeGrav, 1); <\/code><\/pre>\n<p>  <\/div>\n<\/div>\n<p>  \u0422\u0435\u043f\u0435\u0440\u044c \u0441\u0442\u043e\u0438\u0442 \u0440\u0430\u0441\u0441\u043a\u0430\u0437\u0430\u0442\u044c \u043e \u0444\u043e\u0440\u043c\u0430\u0442\u0435 \u0440\u0430\u0431\u043e\u0442\u044b \u0441 3D \u0442\u0435\u043b\u043e\u043c. \u0422\u0443\u0442 \u0432\u0441\u0451 \u043f\u0440\u043e\u0441\u0442\u043e. \u042d\u0442\u043e \u043e\u0431\u044a\u0435\u043a\u0442, \u0441\u043e\u0441\u0442\u043e\u044f\u0449\u0438\u0439 \u0438\u0437 \u0442\u0440\u0451\u0445 \u043c\u0430\u0441\u0441\u0438\u0432\u043e\u0432: \u0432\u0435\u0440\u0448\u0438\u043d\u044b, \u043d\u043e\u0440\u043c\u0430\u043b\u0438 \u0438 \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u044b\u0435 \u0433\u0440\u0430\u043d\u0438.<\/p>\n<pre><code class=\"javascript\">var obj = { \tvertices: [], \tnormals: [], \tfaces: [] }; <\/code><\/pre>\n<p>  \u041c\u0430\u0441\u0441\u0438\u0432 \u0432\u0435\u0440\u0448\u0438\u043d \u0445\u0440\u0430\u043d\u0438\u0442 \u043e\u0431\u044a\u0435\u043a\u0442\u044b-\u0432\u0435\u043a\u0442\u043e\u0440\u044b \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442 \u0432\u0435\u0440\u0448\u0438\u043d. \u041c\u0430\u0441\u0441\u0438\u0432 \u043d\u043e\u0440\u043c\u0430\u043b\u0435\u0439 \u2014 \u0432\u0435\u043a\u0442\u043e\u0440\u044b \u043d\u043e\u0440\u043c\u0430\u043b\u0435\u0439 \u0432\u0435\u0440\u0448\u0438\u043d. \u041c\u0430\u0441\u0441\u0438\u0432 \u0433\u0440\u0430\u043d\u0435\u0439 \u2014 \u043c\u0430\u0441\u0441\u0438\u0432\u044b \u0438\u0437 \u0442\u0440\u0451\u0445 \u0447\u0438\u0441\u0435\u043b, \u0445\u0440\u0430\u043d\u044f\u0449\u0438\u0435 \u043d\u043e\u043c\u0435\u0440\u0430 \u0432\u0435\u0440\u0448\u0438\u043d.<\/p>\n<p>  \u041c\u043e\u0434\u0435\u043b\u044c \u043a\u043e\u043c\u0435\u0442\u044b \u0427\u0443\u0440\u044e\u043c\u043e\u0432\u0430-\u0413\u0435\u0440\u0430\u0441\u0438\u043c\u0435\u043d\u043a\u043e \u044f \u0441\u043a\u0430\u0447\u0430\u043b \u0441 <a href=\"http:\/\/blogs.esa.int\/rosetta\/2014\/10\/03\/measuring-comet-67pc-g\/\">\u0441\u0430\u0439\u0442\u0430<\/a> ESA \u0438 \u0443\u043f\u0440\u043e\u0441\u0442\u0438\u043b \u0435\u0451 \u0432 3Ds Max. \u0412 \u0438\u0441\u0445\u043e\u0434\u043d\u043e\u0439 \u043c\u043e\u0434\u0435\u043b\u0438 \u0431\u044b\u043b\u043e \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0434\u0435\u0441\u044f\u0442\u043a\u043e\u0432 \u0442\u044b\u0441\u044f\u0447 \u0432\u0435\u0440\u0448\u0438\u043d \u0438 \u0433\u0440\u0430\u043d\u0435\u0439, \u043d\u043e \u0434\u043b\u044f \u043d\u0430\u0448\u0435\u0439 \u0437\u0430\u0434\u0430\u0447\u0438 \u044d\u0442\u043e \u0441\u043b\u0438\u0448\u043a\u043e\u043c \u043c\u043d\u043e\u0433\u043e, \u0442. \u043a. \u0432\u044b\u0447\u0438\u0441\u043b\u0438\u0442\u0435\u043b\u044c\u043d\u0430\u044f \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u0430 \u0437\u0430\u0432\u0438\u0441\u0438\u0442 \u043e\u0442 \u043f\u0440\u043e\u0438\u0437\u0432\u0435\u0434\u0435\u043d\u0438\u044f \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430 \u0432\u0435\u0440\u0448\u0438\u043d \u043d\u0430 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0433\u0440\u0430\u043d\u0435\u0439. \u041c\u043e\u0434\u0435\u043b\u044c \u0441\u043e\u0445\u0440\u0430\u043d\u0435\u043d\u0430 \u0432 \u0444\u043e\u0440\u043c\u0430\u0442\u0435 <a href=\"https:\/\/ru.wikipedia.org\/wiki\/Obj\">obj<\/a>.<\/p>\n<p>  \u0412 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0435 three.js \u0435\u0441\u0442\u044c \u0444\u0443\u043d\u043a\u0446\u0438\u044f OBJLoader \u0434\u043b\u044f \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438 \u044d\u0442\u043e\u0433\u043e \u0444\u043e\u0440\u043c\u0430\u0442\u0430, \u043d\u043e \u043f\u0440\u0438 \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0435 \u043e\u0441\u0442\u0430\u0435\u0442\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044f \u043e \u0432\u0435\u0440\u0448\u0438\u043d\u0430\u0445, \u0430 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044f \u043e \u0433\u0440\u0430\u043d\u044f\u0445 \u0442\u0435\u0440\u044f\u0435\u0442\u0441\u044f, \u0447\u0442\u043e \u043d\u0435 \u043f\u043e\u0434\u0445\u043e\u0434\u0438\u0442 \u0434\u043b\u044f \u043d\u0430\u0448\u0435\u0439 \u0437\u0430\u0434\u0430\u0447\u0438. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u044f \u0435\u0451 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043c\u043e\u0434\u0438\u0444\u0438\u0446\u0438\u0440\u043e\u0432\u0430\u043b.<\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u041a\u043e\u0434<\/b><\/p>\n<div class=\"spoiler_text\">\n<pre><code class=\"javascript\">function objLoad(url) { \tvar result; \tvar xhr = new XMLHttpRequest(); \txhr.open('GET', url, false); \txhr.onreadystatechange = function(){ \t\tif (xhr.readyState != 4) return; \t\tif (xhr.status != 200) { \t\t\tresult = xhr.status + ': ' + xhr.statusText + ': ' + xhr.responseText; \t\t} \t\telse { \t\t\tresult = xhr; \t\t} \t} \txhr.send(null); \treturn result; }  function objParse(url) { \tvar txt = objLoad(url).responseText; \tvar lines = txt.split('\\n'); \tvar result; \t \t\/\/ v float float float \tvar vertex_pattern = \/v( +[\\d|\\.|\\+|\\-|e|E]+)( +[\\d|\\.|\\+|\\-|e|E]+)( +[\\d|\\.|\\+|\\-|e|E]+)\/; \t\/\/ f vertex vertex vertex ... \tvar face_pattern1 = \/f( +-?\\d+)( +-?\\d+)( +-?\\d+)( +-?\\d+)?\/; \t\/\/ f vertex\/uv vertex\/uv vertex\/uv ... \tvar face_pattern2 = \/f( +(-?\\d+)\\\/(-?\\d+))( +(-?\\d+)\\\/(-?\\d+))( +(-?\\d+)\\\/(-?\\d+))( +(-?\\d+)\\\/(-?\\d+))?\/; \t\/\/ f vertex\/uv\/normal vertex\/uv\/normal vertex\/uv\/normal ... \tvar face_pattern3 = \/f( +(-?\\d+)\\\/(-?\\d+)\\\/(-?\\d+))( +(-?\\d+)\\\/(-?\\d+)\\\/(-?\\d+))( +(-?\\d+)\\\/(-?\\d+)\\\/(-?\\d+))( +(-?\\d+)\\\/(-?\\d+)\\\/(-?\\d+))?\/; \t\/\/ f vertex\/\/normal vertex\/\/normal vertex\/\/normal ... \tvar face_pattern4 = \/f( +(-?\\d+)\\\/\\\/(-?\\d+))( +(-?\\d+)\\\/\\\/(-?\\d+))( +(-?\\d+)\\\/\\\/(-?\\d+))( +(-?\\d+)\\\/\\\/(-?\\d+))?\/;  \tvar obj = { \t\tvertices: [], \t\tnormals: [], \t\tfaces: [] \t};  \tfor (var i = 0; i &lt; lines.length; i++) { \t\tvar line = lines[i].trim(); \t\tif ((result = vertex_pattern.exec(line)) !== null) { \t\t\tobj.vertices.push(new vector3( \t\t\t\tparseFloat(result[1]), \t\t\t\tparseFloat(result[2]), \t\t\t\tparseFloat(result[3]) \t\t\t)); \t\t}else if ((result = face_pattern1.exec(line)) !== null) { \t\t\tobj.faces.push([ \t\t\t\tparseInt(result[1]), \t\t\t\tparseInt(result[2]), \t\t\t\tparseInt(result[3]) \t\t\t]); \t\t\tif (result[4]) \t\t\t\tobj.faces.push([ \t\t\t\t\tparseInt(result[1]), \t\t\t\t\tparseInt(result[3]), \t\t\t\t\tparseInt(result[4]) \t\t\t\t]); \t\t}else if ((result = face_pattern2.exec(line)) !== null) { \t\t\tobj.faces.push([ \t\t\t\tparseInt(result[2]), \t\t\t\tparseInt(result[5]), \t\t\t\tparseInt(result[8]) \t\t\t]); \t\t\tif (result[11]) \t\t\t\tobj.faces.push([ \t\t\t\t\tparseInt(result[2]), \t\t\t\t\tparseInt(result[8]), \t\t\t\t\tparseInt(result[11]) \t\t\t\t]); \t\t}else if ((result = face_pattern3.exec(line)) !== null) { \t\t\tobj.faces.push([ \t\t\t\tparseInt(result[2]), \t\t\t\tparseInt(result[6]), \t\t\t\tparseInt(result[10]) \t\t\t]); \t\t\tif (result[14]) \t\t\t\tobj.faces.push([ \t\t\t\t\tparseInt(result[2]), \t\t\t\t\tparseInt(result[10]), \t\t\t\t\tparseInt(result[14]) \t\t\t\t]); \t\t}else if ((result = face_pattern4.exec(line)) !== null) { \t\t\tobj.faces.push([ \t\t\t\tparseInt(result[2]), \t\t\t\tparseInt(result[5]), \t\t\t\tparseInt(result[8]) \t\t\t]); \t\t\tif (result[11]) \t\t\t\tobj.faces.push([ \t\t\t\t\tparseInt(result[2]), \t\t\t\t\tparseInt(result[8]), \t\t\t\t\tparseInt(result[11]) \t\t\t\t]); \t\t} \t} \tobj.normals = computeNormalizeNormals(obj); \treturn obj; } <\/code><\/pre>\n<p>  <\/div>\n<\/div>\n<p>  \u0418\u0442\u0430\u043a, \u043e\u0431\u044a\u0435\u043a\u0442 \u0438\u0437 \u0444\u0430\u0439\u043b\u0430 \u043c\u044b \u0437\u0430\u0433\u0440\u0443\u0437\u0438\u043b\u0438, \u0437\u0430\u0442\u0435\u043c \u0432\u044b\u0447\u0438\u0441\u043b\u0438\u043b\u0438 \u0432\u0435\u043a\u0442\u043e\u0440 \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u044f \u0432 \u043a\u0430\u0436\u0434\u043e\u0439 \u0435\u0433\u043e \u0432\u0435\u0440\u0448\u0438\u043d\u0435, \u0442\u0435\u043f\u0435\u0440\u044c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0435\u0433\u043e \u0432\u0438\u0437\u0443\u0430\u043b\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c. \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043d\u0443\u0436\u043d\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0441\u0446\u0435\u043d\u0443, \u043d\u0430\u0441\u0442\u0440\u043e\u0438\u0442\u044c \u043a\u0430\u043c\u0435\u0440\u0443 \u0438 \u0441\u0432\u0435\u0442, \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u0438 \u0440\u0430\u0441\u043a\u0440\u0430\u0441\u0438\u0442\u044c \u043d\u0430\u0448\u0443 \u043c\u043e\u0434\u0435\u043b\u044c.<\/p>\n<p>  \u0421\u0446\u0435\u043d\u0430 \u0441\u043e\u0437\u0434\u0430\u0451\u0442\u0441\u044f \u043f\u0440\u043e\u0441\u0442\u043e.<\/p>\n<pre><code class=\"javascript\">scene = new THREE.Scene(); <\/code><\/pre>\n<p>  \u0421 \u043a\u0430\u043c\u0435\u0440\u043e\u0439 \u0442\u043e\u0436\u0435 \u043d\u0438\u043a\u0430\u043a\u0438\u0445 \u043f\u0440\u043e\u0431\u043b\u0435\u043c.<\/p>\n<pre><code class=\"javascript\">var fieldWidth = 500; \/\/ \u0440\u0430\u0437\u043c\u0435\u0440\u044b \u0445\u043e\u043b\u0441\u0442\u0430 \u0432 \u043f\u0438\u043a\u0441\u0435\u043b\u044f\u0445 var fieldHeight = 500; camera = new THREE.PerspectiveCamera(50, fieldWidth \/ fieldHeight, 0.01, 10000); scene.add(camera); cameraZ = 3 * boundingSphereRadius; \/\/ boundingSphereRadius - \u0440\u0430\u0434\u0438\u0443\u0441 \u0441\u0444\u0435\u0440\u044b, \u043e\u043f\u0438\u0441\u0430\u043d\u043d\u043e\u0439 \u0432\u043e\u043a\u0440\u0443\u0433 \u043d\u0430\u0448\u0435\u0433\u043e \u0442\u0435\u043b\u0430 camera.position.x = 0; camera.position.y = 0; camera.position.z = cameraZ; camera.lookAt(new THREE.Vector3(0, 0, 0)); \/\/ \u043a\u0430\u043c\u0435\u0440\u0430 \u0441\u043c\u043e\u0442\u0440\u0438\u0442 \u0432 \u043d\u0430\u0447\u0430\u043b\u043e \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442 <\/code><\/pre>\n<p>  \u0414\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u043a\u0430\u043c\u0435\u0440\u044b \u043c\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u0438 \u0444\u0443\u043d\u043a\u0446\u0438\u044e THREE.PerspectiveCamera(fov, aspect, near, far), \u0433\u0434\u0435:<\/p>\n<p>  fov \u2014 \u0432\u044b\u0441\u043e\u0442\u0430 \u043f\u043e\u043b\u044f \u0437\u0440\u0435\u043d\u0438\u044f \u043a\u0430\u043c\u0435\u0440\u044b \u0432 \u0433\u0440\u0430\u0434\u0443\u0441\u0430\u0445;<br \/>  aspect \u2014 \u043e\u0442\u043d\u043e\u0448\u0435\u043d\u0438\u0435 \u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u0443\u0433\u043b\u0430 \u0437\u0440\u0435\u043d\u0438\u044f \u043a\u0430\u043c\u0435\u0440\u044b \u043a \u0432\u0435\u0440\u0442\u0438\u043a\u0430\u043b\u044c\u043d\u043e\u043c\u0443;<br \/>  near \u2014 \u0440\u0430\u0441\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0434\u043e \u0431\u043b\u0438\u0436\u043d\u0435\u0433\u043e \u043f\u043b\u0430\u043d\u0430 (\u0442\u043e, \u0447\u0442\u043e \u043d\u0430\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u0431\u043b\u0438\u0436\u0435, \u043d\u0435 \u0431\u0443\u0434\u0435\u0442 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u0442\u044c\u0441\u044f);<br \/>  far \u2014 \u0440\u0430\u0441\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0434\u043e \u0434\u0430\u043b\u044c\u043d\u0435\u0433\u043e \u043f\u043b\u0430\u043d\u0430.<\/p>\n<p>  \u0421\u0442\u0430\u0432\u0438\u043c \u0441\u0432\u0435\u0442.<\/p>\n<pre><code class=\"javascript\">var ambientLight = new THREE.AmbientLight(0xffffff); scene.add(ambientLight); <\/code><\/pre>\n<p>  \u0421\u043e\u0437\u0434\u0430\u0451\u043c \u0432\u0438\u0437\u0443\u0430\u043b\u0438\u0437\u0430\u0442\u043e\u0440.<\/p>\n<pre><code class=\"javascript\">renderer = new THREE.WebGLRenderer({antialias: true}); renderer.setClearColor(0xffffff); \/\/ \u0446\u0432\u0435\u0442 \u0444\u043e\u043d\u0430 renderer.setPixelRatio(window.devicePixelRatio); renderer.setSize(fieldWidth, fieldHeight); \/\/ \u0437\u0430\u0434\u0430\u0451\u043c \u0440\u0430\u0437\u043c\u0435\u0440 \u0445\u043e\u043b\u0441\u0442\u0430 container.appendChild(renderer.domElement); \/\/ \u043f\u0440\u0438\u0432\u044f\u0437\u044b\u0432\u0430\u0435\u043c\u0441\u044f \u043a \u0445\u043e\u043b\u0441\u0442\u0443 <\/code><\/pre>\n<p>  <\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u0412\u0441\u0451 \u0432\u043c\u0435\u0441\u0442\u0435<\/b><\/p>\n<div class=\"spoiler_text\">\n<pre><code class=\"javascript\">var container; var camera, scene, renderer; var axis; var mesh; var boundingSphereRadius, cameraZ; var lines = []; var angleGeneral = 0;  function init() { \tcontainer = document.getElementById('container'); \tscene = new THREE.Scene(); \t \tvar fieldWidth = 500; \tvar fieldHeight = 500; \tcamera = new THREE.PerspectiveCamera(50, fieldWidth \/ fieldHeight, 0.01, 10000); \tscene.add(camera); \tvar ambientLight = new THREE.AmbientLight(0xffffff); \tscene.add(ambientLight);  \tloadModel(); \t \tcameraZ = 3 * boundingSphereRadius; \tcamera.position.x = 0; \tcamera.position.y = 0; \tcamera.position.z = cameraZ; \tcamera.lookAt(new THREE.Vector3(0, 0, 0)); \t \taxis = new THREE.Vector3(0.6, 0.8, 0); \/\/   \trenderer = new THREE.WebGLRenderer({antialias: true}); \trenderer.setClearColor(0xffffff); \trenderer.setPixelRatio(window.devicePixelRatio); \trenderer.setSize(fieldWidth, fieldHeight); \tcontainer.appendChild(renderer.domElement); } <\/code><\/pre>\n<p>  <\/div>\n<\/div>\n<p>  \u0414\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u043c\u043e\u0434\u0435\u043b\u044f\u043c\u0438 \u0432 three.js \u0443\u0434\u043e\u0431\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043a\u043b\u0430\u0441\u0441 BufferGeometry.<\/p>\n<pre><code class=\"javascript\">var geometry = new THREE.BufferGeometry(); <\/code><\/pre>\n<p>  \u0417\u0430\u0434\u0430\u0451\u043c \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b.<\/p>\n<pre><code class=\"javascript\">var material = new THREE.MeshLambertMaterial( { \tside: THREE.FrontSide, \/\/ \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0430\u0442\u044c\u0441\u044f \u0431\u0443\u0434\u0435\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u0435\u0440\u0435\u0434\u043d\u044f\u044f \u0441\u0442\u043e\u0440\u043e\u043d\u0430 \u0433\u0440\u0430\u043d\u0438 \tvertexColors: THREE.VertexColors \/\/ \u0433\u0440\u0430\u043d\u0438 \u043e\u043a\u0440\u0430\u0448\u0438\u0432\u0430\u044e\u0442\u0441\u044f \u0433\u0440\u0430\u0434\u0438\u0435\u043d\u0442\u043e\u043c \u043f\u043e \u0446\u0432\u0435\u0442\u0430\u043c \u0438\u0445 \u0432\u0435\u0440\u0448\u0438\u043d }); <\/code><\/pre>\n<p>  \u0417\u0430\u0433\u0440\u0443\u0436\u0430\u0435\u043c \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u044b \u0432\u0435\u0440\u0448\u0438\u043d.<\/p>\n<pre><code class=\"javascript\">var vertices = new Float32Array(9 * object3d.faces.length); for (var i = 0; i &lt; object3d.faces.length; i++) { \tfor (var j = 0; j &lt; 3; j++) { \t\tvertices[9*i + 3*j    ] = object3d.vertices[object3d.faces[i][j] - 1].x; \t\tvertices[9*i + 3*j + 1] = object3d.vertices[object3d.faces[i][j] - 1].y; \t\tvertices[9*i + 3*j + 2] = object3d.vertices[object3d.faces[i][j] - 1].z; \t} } geometry.addAttribute('position', new THREE.BufferAttribute(vertices, 3)); <\/code><\/pre>\n<p>  \u0412\u044b\u0447\u0438\u0441\u043b\u044f\u0435\u043c \u0446\u0432\u0435\u0442 \u0432\u0435\u0440\u0448\u0438\u043d.<\/p>\n<pre><code class=\"javascript\">var colors = addColor(); geometry.addAttribute('color', new THREE.BufferAttribute(colors, 3));  function addColor() { \tvar colorMin = [0.0, 0.6, 1.0]; \/\/ \u0446\u0432\u0435\u0442 \u0442\u043e\u0447\u0435\u043a \u0441 \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u043c \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u0435\u043c \tvar colorMax = [1.0, 0.0, 0.0]; \/\/ \u0442\u043e \u0436\u0435 \u0441 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u043c \tvar colors = new Float32Array(9 * object3d.faces.length); \tfor (var i = 0; i &lt; object3d.faces.length; i++) { \t\tfor (var j = 0; j &lt; 3; j++) { \t\t\tvar intensity = (abs_force[object3d.faces[i][j] - 1] - forceMin) \/ (forceMax - forceMin); \t\t\tcolors[9*i + 3*j    ] = colorMin[0] + (colorMax[0] - colorMin[0]) * intensity; \t\t\tcolors[9*i + 3*j + 1] = colorMin[1] + (colorMax[1] - colorMin[1]) * intensity; \t\t\tcolors[9*i + 3*j + 2] = colorMin[2] + (colorMax[2] - colorMin[2]) * intensity; \t\t} \t} \treturn colors; } <\/code><\/pre>\n<p>  \u0422\u0430\u043a\u0436\u0435 \u043d\u0430\u043c \u043f\u043e\u043d\u0430\u0434\u043e\u0431\u0438\u0442\u0441\u044f \u043e\u0442\u043e\u0431\u0440\u0430\u0437\u0438\u0442\u044c \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u044f \u0441\u0432\u043e\u0431\u043e\u0434\u043d\u043e\u0433\u043e \u043f\u0430\u0434\u0435\u043d\u0438\u044f \u0432 \u043a\u0430\u0436\u0434\u043e\u0439 \u0432\u0435\u0440\u0448\u0438\u043d\u0435.<\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u041a\u043e\u0434<\/b><\/p>\n<div class=\"spoiler_text\">\n<pre><code class=\"javascript\">var lines;  function addLines() { \tlines = new Array(); \t \tfor (var i = 0; i &lt; object3d.vertices.length; i++) { \t\tvar color; \t\tvar ratio; \t\tif (angle_force[i] &lt; 90) { \t\t\tcolor = 0x000000; \/\/ \u0412\u0435\u043a\u0442\u043e\u0440 \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u044f \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d \u0432 \u0441\u0442\u043e\u0440\u043e\u043d\u0443 \u0442\u0435\u043b\u0430 \t\t\tratio = -0.2 * boundingSphereRadius \/ forceMax; \t\t} \t\telse { \t\t\tcolor = 0xdddddd; \/\/ \u0412\u0435\u043a\u0442\u043e\u0440 \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u044f \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d \u043d\u0430\u0440\u0443\u0436\u0443 \t\t\tratio = 0.2 * boundingSphereRadius \/ forceMax; \t\t} \t\t \t\tvar material = new THREE.LineBasicMaterial({ \t\t\tcolor: color \t\t}); \t\t \t\tvar geometry = new THREE.Geometry(); \t\tvar point1 = object3d.vertices[i]; \t\tvar point2 = new THREE.Vector3(); \t\tpoint2.copy(force[i]); \t\tpoint2.addVectors(point1, point2.multiplyScalar(ratio)); \t\tgeometry.vertices.push( \t\t\tnew THREE.Vector3(point1.x, point1.y, point1.z), \t\t\tnew THREE.Vector3(point2.x, point2.y, point2.z) \t\t); \t \t\tvar line = new THREE.Line(geometry, material); \t\trotateAroundWorldAxis(line, axis, angleGeneral); \t\tif (hair.checked)  \t\t\tscene.add(line); \t\tlines.push(line); \t} } <\/code><\/pre>\n<p>  <\/div>\n<\/div>\n<p>  \u0421 \u0432\u0438\u0437\u0443\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0435\u0439 \u0437\u0430\u043a\u043e\u043d\u0447\u0438\u043b\u0438. \u0421\u043c\u043e\u0442\u0440\u0438\u043c, \u0447\u0442\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u043e\u0441\u044c.<\/p>\n<p>  <a href=\"http:\/\/www.anthelion.ru\/gravitybodies\/comet.html\">\u0414\u0435\u043c\u043e 1<\/a>.<\/p>\n<p>  \u041a\u0430\u043a \u0432\u0438\u0434\u0438\u043c, \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u0435 \u0441\u0432\u043e\u0431\u043e\u0434\u043d\u043e\u0433\u043e \u043f\u0430\u0434\u0435\u043d\u0438\u044f \u043d\u0430 \u043a\u043e\u043c\u0435\u0442\u0435 \u043e\u0442 40 \u0434\u043e 80 \u0442\u044b\u0441\u044f\u0447 \u0440\u0430\u0437 \u043c\u0435\u043d\u044c\u0448\u0435, \u0447\u0435\u043c \u043d\u0430 \u0417\u0435\u043c\u043b\u0435. \u041c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0435 \u043e\u0442\u043a\u043b\u043e\u043d\u0435\u043d\u0438\u0435 \u0432\u0435\u043a\u0442\u043e\u0440\u0430 \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u044f \u043e\u0442 \u043d\u043e\u0440\u043c\u0430\u043b\u0438 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u043f\u043e\u0440\u044f\u0434\u043a\u0430 60-70 \u0433\u0440\u0430\u0434\u0443\u0441\u043e\u0432. \u041c\u0435\u043b\u043a\u0438\u0435 \u0438 \u043a\u0440\u0443\u043f\u043d\u044b\u0435 \u043a\u0430\u043c\u043d\u0438 \u043d\u0430 \u044d\u0442\u0438\u0445 \u0443\u0447\u0430\u0441\u0442\u043a\u0430\u0445 \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e \u043d\u0435 \u0437\u0430\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u044e\u0442\u0441\u044f \u0438 \u043f\u043e\u0442\u0438\u0445\u043e\u043d\u044c\u043a\u0443 \u0441\u043a\u0430\u0442\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u0432 \u043e\u0431\u043b\u0430\u0441\u0442\u0438, \u0433\u0434\u0435 \u0443\u0433\u043e\u043b \u043d\u0435 \u0442\u0430\u043a\u043e\u0439 \u0431\u043e\u043b\u044c\u0448\u043e\u0439.<\/p>\n<p>  \u041c\u043e\u0436\u043d\u043e \u043f\u043e\u0438\u0433\u0440\u0430\u0442\u044c\u0441\u044f \u0441 \u0442\u0435\u043b\u0430\u043c\u0438 \u0434\u0440\u0443\u0433\u043e\u0439 \u0444\u043e\u0440\u043c\u044b. <a href=\"http:\/\/www.anthelion.ru\/gravitybodies\/bodies.html\">\u0414\u0435\u043c\u043e 2<\/a>.<\/p>\n<p>  \u0412\u0438\u0434\u0438\u043c, \u0447\u0442\u043e \u0434\u043b\u044f \u043a\u0443\u0431\u0430 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0435 \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u0435 (\u0432 \u0446\u0435\u043d\u0442\u0440\u0435 \u0433\u0440\u0430\u043d\u0438) \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 1,002 \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u044f \u0434\u043b\u044f \u0448\u0430\u0440\u0430 \u0442\u0430\u043a\u043e\u0439 \u0436\u0435 \u043c\u0430\u0441\u0441\u044b, \u043d\u043e \u043d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435 \u044d\u0442\u0430 \u0432\u0435\u043b\u0438\u0447\u0438\u043d\u0430 \u0447\u0443\u0442\u044c \u043c\u0435\u043d\u044c\u0448\u0435 \u0435\u0434\u0438\u043d\u0438\u0446\u044b (\u0441\u044b\u0433\u0440\u0430\u043b\u043e \u0440\u043e\u043b\u044c \u0442\u043e, \u0447\u0442\u043e \u043c\u044b \u0441\u0447\u0438\u0442\u0430\u043b\u0438 \u0441 \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0439 \u043f\u043e\u0433\u0440\u0435\u0448\u043d\u043e\u0441\u0442\u044c\u044e 0,01). \u0414\u043b\u044f \u043a\u0443\u0431\u0430, \u0432 \u043e\u0442\u043b\u0438\u0447\u0438\u0435 \u043e\u0442 \u0442\u0435\u0442\u0440\u0430\u044d\u0434\u0440\u0430, \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0442 \u0442\u043e\u0447\u043d\u044b\u0435 \u0444\u043e\u0440\u043c\u0443\u043b\u044b \u0440\u0430\u0441\u0447\u0451\u0442\u0430 \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u0439 \u0438 \u0442\u043e\u0447\u043d\u043e\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u0434\u043b\u044f \u0446\u0435\u043d\u0442\u0440\u0430 \u0433\u0440\u0430\u043d\u0438 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 (\u0434\u043b\u044f \u043a\u0443\u0431\u0430 \u0441\u043e \u0441\u0442\u043e\u0440\u043e\u043d\u043e\u0439, \u0440\u0430\u0432\u043d\u043e\u0439 1):<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/files\/0ec\/426\/ab3\/0ec426ab3d214bc493c18f9d6f036815.png\"\/><\/p>\n<p>  \u0414\u043b\u044f \u0448\u0430\u0440\u0430 \u0442\u043e\u0433\u043e \u0436\u0435 \u043e\u0431\u044a\u0451\u043c\u0430:<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/files\/86a\/48d\/47e\/86a48d47e0f14e1dadf9fe3cb8c35911.png\"\/><\/p>\n<p>  \u0418\u0445 \u043e\u0442\u043d\u043e\u0448\u0435\u043d\u0438\u0435 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 0.999376 \u0438 \u043b\u0438\u0448\u044c \u0441\u043b\u0435\u0433\u043a\u0430 \u043d\u0435 \u0434\u043e\u0442\u044f\u0433\u0438\u0432\u0430\u0435\u0442 \u0434\u043e \u0435\u0434\u0438\u043d\u0438\u0446\u044b.<\/p>\n<p>  \u0412 \u0437\u0430\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u0432\u043e\u043f\u0440\u043e\u0441. \u0421\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0442 \u043b\u0438 \u0442\u0435\u043b\u0430, \u0443 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0445\u043e\u0442\u044f \u0431\u044b \u0432 \u043e\u0434\u043d\u043e\u0439 \u0442\u043e\u0447\u043a\u0435 \u043e\u0442\u043d\u043e\u0448\u0435\u043d\u0438\u0435 \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u043e\u0439 \u0432\u0435\u043b\u0438\u0447\u0438\u043d\u044b \u0433\u0440\u0430\u0432\u0438\u0442\u0430\u0446\u0438\u043e\u043d\u043d\u043e\u0433\u043e \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u044f \u043a \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u044e \u043d\u0430 \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u0438 \u0448\u0430\u0440\u0430 \u0442\u043e\u0439 \u0436\u0435 \u043c\u0430\u0441\u0441\u044b \u0438 \u043e\u0431\u044a\u0451\u043c\u0430 \u0431\u043e\u043b\u044c\u0448\u0435 \u0435\u0434\u0438\u043d\u0438\u0446\u044b? \u0415\u0441\u043b\u0438 \u0434\u0430, \u0442\u043e \u0434\u043b\u044f \u043a\u0430\u043a\u043e\u0433\u043e \u0442\u0435\u043b\u0430 \u044d\u0442\u043e \u043e\u0442\u043d\u043e\u0448\u0435\u043d\u0438\u0435 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e? \u0412\u043e \u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0440\u0430\u0437 \u044d\u0442\u043e \u043e\u0442\u043d\u043e\u0448\u0435\u043d\u0438\u0435 \u0431\u043e\u043b\u044c\u0448\u0435 \u0435\u0434\u0438\u043d\u0438\u0446\u044b, \u0432 \u0440\u0430\u0437\u044b \u0438\u043b\u0438 \u043d\u0430 \u0434\u043e\u043b\u0438 \u043f\u0440\u043e\u0446\u0435\u043d\u0442\u043e\u0432?       <\/p>\n<div class=\"clear\"><\/div>\n<p> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"http:\/\/habrahabr.ru\/post\/271451\/\"> http:\/\/habrahabr.ru\/post\/271451\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>       \u0418\u0437 \u0437\u0430\u043a\u043e\u043d\u0430 \u0432\u0441\u0435\u043c\u0438\u0440\u043d\u043e\u0433\u043e \u0442\u044f\u0433\u043e\u0442\u0435\u043d\u0438\u044f \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u043e, \u0447\u0442\u043e \u043d\u0430 \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u0438 \u0442\u0435\u043b \u0448\u0430\u0440\u043e\u043e\u0431\u0440\u0430\u0437\u043d\u043e\u0439 \u0444\u043e\u0440\u043c\u044b \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u0435 \u0441\u0432\u043e\u0431\u043e\u0434\u043d\u043e\u0433\u043e \u043f\u0430\u0434\u0435\u043d\u0438\u044f \u043f\u043e\u0441\u0442\u043e\u044f\u043d\u043d\u043e \u043f\u043e \u043c\u043e\u0434\u0443\u043b\u044e \u0438 \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043e \u043a \u0446\u0435\u043d\u0442\u0440\u0443 \u0448\u0430\u0440\u0430. \u0414\u043b\u044f \u0442\u0435\u043b \u043d\u0435\u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e\u0439 \u0444\u043e\u0440\u043c\u044b \u044d\u0442\u043e \u043f\u0440\u0430\u0432\u0438\u043b\u043e, \u043e\u0447\u0435\u0432\u0438\u0434\u043d\u043e, \u043d\u0435 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442\u0441\u044f. \u0412 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u044f \u043f\u043e\u043a\u0430\u0436\u0443 \u0441\u043f\u043e\u0441\u043e\u0431 \u0440\u0430\u0441\u0447\u0451\u0442\u0430 \u0438 \u0432\u0438\u0437\u0443\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u044f \u0441\u0432\u043e\u0431\u043e\u0434\u043d\u043e\u0433\u043e \u043f\u0430\u0434\u0435\u043d\u0438\u044f \u0434\u043b\u044f \u0442\u0430\u043a\u0438\u0445 \u0442\u0435\u043b. \u0420\u0430\u0441\u0447\u0451\u0442 \u0431\u0443\u0434\u0435\u043c \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u044c \u043d\u0430 JavaScript, \u0432\u0438\u0437\u0443\u0430\u043b\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u2014 \u043d\u0430 WebGL \u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435\u043c \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 <a href=\"http:\/\/threejs.org\">three.js<\/a>.<\/p>\n<p>  \u0412 \u0438\u0442\u043e\u0433\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u043c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435 (\u043a\u0440\u0430\u0441\u043d\u044b\u043c \u0446\u0432\u0435\u0442\u043e\u043c \u043e\u0442\u043c\u0435\u0447\u0435\u043d\u044b \u043e\u0431\u043b\u0430\u0441\u0442\u0438 \u0441 \u0431\u043e\u043b\u044c\u0448\u0438\u043c \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u0435\u043c \u0441\u0432\u043e\u0431\u043e\u0434\u043d\u043e\u0433\u043e \u043f\u0430\u0434\u0435\u043d\u0438\u044f, \u0441\u0438\u043d\u0438\u043c \u2014 \u0441 \u043c\u0430\u043b\u044b\u043c):<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/files\/2eb\/f0b\/258\/2ebf0b258ec644a792a1f9295b22d5bb.png\"\/>  <\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-268743","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/268743","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=268743"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/268743\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=268743"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=268743"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=268743"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}