{"id":4029,"date":"2023-07-14T02:03:32","date_gmt":"2023-07-14T02:03:32","guid":{"rendered":"https:\/\/statorials.org\/pt\/r-microbenchmark\/"},"modified":"2023-07-14T02:03:32","modified_gmt":"2023-07-14T02:03:32","slug":"r-microbenchmark","status":"publish","type":"post","link":"https:\/\/statorials.org\/pt\/r-microbenchmark\/","title":{"rendered":"R: como usar o pacote microbenchmark para medir o tempo de execu\u00e7\u00e3o"},"content":{"rendered":"<p><\/p>\n<hr>\n<p><span style=\"color: #000000;\">Voc\u00ea pode usar o pacote <strong>microbenchmark<\/strong> em R para comparar o tempo de execu\u00e7\u00e3o de diferentes express\u00f5es.<\/span><\/p>\n<p> <span style=\"color: #000000;\">Voc\u00ea pode usar a seguinte sintaxe para fazer isso:<\/span><\/p>\n<pre style=\"background-color: #ececec; font-size: 15px;\"> <strong><span style=\"color: #008000;\">library<\/span> (microbenchmark)\n\n<span style=\"color: #008080;\">#compare execution time of two different expressions\n<\/span>microbenchmark(\n  expression1,\n  expression2)\n)\n<\/strong><\/pre>\n<p> <span style=\"color: #000000;\">O exemplo a seguir mostra como usar essa sintaxe na pr\u00e1tica.<\/span><\/p>\n<h2> <span style=\"color: #000000;\"><strong>Exemplo: Usando microbenchmark() em R<\/strong><\/span><\/h2>\n<p> <span style=\"color: #000000;\">Suponha que temos o seguinte quadro de dados em R que cont\u00e9m informa\u00e7\u00f5es sobre os pontos marcados por jogadores de v\u00e1rios times de basquete:<\/span><\/p>\n<pre style=\"background-color: #ececec; font-size: 15px;\"> <strong><span style=\"color: #008000;\"><span style=\"color: #000000;\"><span style=\"color: #008080;\">#make this example reproducible\n<\/span>set. <span style=\"color: #3366ff;\">seed<\/span> ( <span style=\"color: #008000;\">1<\/span> )\n\n<span style=\"color: #008080;\">#create data frame\n<\/span>df &lt;- data. <span style=\"color: #3366ff;\">frame<\/span> (team=rep(c(' <span style=\"color: #ff0000;\">A<\/span> ', ' <span style=\"color: #ff0000;\">B<\/span> '), each= <span style=\"color: #008000;\">500<\/span> ),\n                 points=rnorm( <span style=\"color: #008000;\">1000<\/span> , mean= <span style=\"color: #008000;\">20<\/span> ))\n\n<span style=\"color: #008080;\">#view data frame\n<\/span>head(df)\n\n  team points\n1 A 19.37355\n2 A 20.18364\n3 A 19.16437\n4 A 21.59528\n5 A 20.32951\n6 A 19.17953\n<\/span><\/span><\/strong><\/pre>\n<p> <span style=\"color: #000000;\">Agora, suponha que queiramos calcular a m\u00e9dia de pontos marcados pelos jogadores de cada equipe usando dois m\u00e9todos diferentes:<\/span><\/p>\n<ul>\n<li> <span style=\"color: #000000;\"><strong>M\u00e9todo 1<\/strong> : Use <strong>Aggregate()<\/strong> da Base R<\/span><\/li>\n<li> <span style=\"color: #000000;\"><strong>M\u00e9todo 2<\/strong> : Use <strong>group_by()<\/strong> e <strong>summarise_at()<\/strong> do dplyr<\/span><\/li>\n<\/ul>\n<p> <span style=\"color: #000000;\">Podemos usar a fun\u00e7\u00e3o <strong>microbenchmark()<\/strong> para medir o tempo que leva para executar cada uma destas express\u00f5es:<\/span><\/p>\n<pre style=\"background-color: #ececec; font-size: 15px;\"> <strong><span style=\"color: #008000;\">library<\/span> (microbenchmark)\n<span style=\"color: #008000;\">library<\/span> (dplyr)\n\n<span style=\"color: #008080;\">#time how long it takes to calculate mean value of points by team\n<\/span>microbenchmark(\n  aggregate(df$points, list(df$team), FUN=mean),\n  df %&gt;% group_by(team) %&gt;% summarise_at(vars(points), list(name = mean))\n)\n\nUnit: milliseconds\n                                                                    express\n                         aggregate(df$points, list(df$team), FUN = mean)\n df %&gt;% group_by(team) %&gt;% summarise_at(vars(points), list(name = mean))\n      min lq mean median uq max neval cld\n 1.307908 1.524078 1.852167 1.743568 2.093813 4.67408 100 a \n 6.788584 7.810932 9.946286 8.914692 10.239904 56.20928 100 b\n<\/strong><\/pre>\n<p> <span style=\"color: #000000;\">A fun\u00e7\u00e3o <strong>microbenchmark()<\/strong> executa cada express\u00e3o 100 vezes e mede as seguintes m\u00e9tricas:<\/span><\/p>\n<ul>\n<li> <span style=\"color: #000000;\"><strong>min<\/strong> : Tempo m\u00ednimo necess\u00e1rio para execu\u00e7\u00e3o<\/span><\/li>\n<li> <span style=\"color: #000000;\"><strong>lq<\/strong> : quartil inferior (percentil 25) de tempo necess\u00e1rio para concluir<\/span><\/li>\n<li> <span style=\"color: #000000;\"><strong>M\u00e9dia<\/strong> : Tempo m\u00e9dio necess\u00e1rio para execu\u00e7\u00e3o<\/span><\/li>\n<li> <span style=\"color: #000000;\"><strong>mediana<\/strong> : tempo m\u00e9dio de execu\u00e7\u00e3o<\/span><\/li>\n<li> <span style=\"color: #000000;\"><strong>uq<\/strong> : quartil superior (percentil 75) de tempo necess\u00e1rio para execu\u00e7\u00e3o<\/span><\/li>\n<li> <span style=\"color: #000000;\"><strong>max<\/strong> : Tempo m\u00e1ximo necess\u00e1rio para execu\u00e7\u00e3o<\/span><\/li>\n<li> <span style=\"color: #000000;\"><strong>neval<\/strong> : N\u00famero de vezes que cada express\u00e3o foi avaliada<\/span><\/li>\n<\/ul>\n<p> <span style=\"color: #000000;\">Normalmente, observamos apenas o tempo m\u00e9dio ou mediano necess\u00e1rio para executar cada express\u00e3o.<\/span><\/p>\n<p> <span style=\"color: #000000;\">Pelo resultado podemos ver:<\/span><\/p>\n<ul>\n<li> <span style=\"color: #000000;\">Demorou em m\u00e9dia <strong>1.852 milissegundos<\/strong> para calcular a m\u00e9dia de pontos da equipe usando o m\u00e9todo baseado em R.<\/span><\/li>\n<li> <span style=\"color: #000000;\">Demorou em m\u00e9dia <strong>9,946 milissegundos<\/strong> para calcular a m\u00e9dia de pontos por equipe usando o m\u00e9todo dplyr.<\/span><\/li>\n<\/ul>\n<p> <span style=\"color: #000000;\">Com base nestes resultados, conclu\u00edmos que o m\u00e9todo base R \u00e9 significativamente mais r\u00e1pido.<\/span><\/p>\n<p> <span style=\"color: #000000;\">Tamb\u00e9m podemos usar a fun\u00e7\u00e3o <strong>boxplot()<\/strong> para visualizar a distribui\u00e7\u00e3o dos tempos necess\u00e1rios para executar cada express\u00e3o:<\/span> <\/p>\n<pre style=\"background-color: #ececec; font-size: 15px;\"> <strong><span style=\"color: #008000;\">library<\/span> (microbenchmark)\n<span style=\"color: #008000;\">library<\/span> (dplyr)\n\n<span style=\"color: #008080;\">#time how long it takes to calculate mean value of points by team\n<\/span>results &lt;- microbenchmark(\n  aggregate(df$points, list(df$team), FUN=mean),\n  df %&gt;% group_by(team) %&gt;% summarise_at(vars(points), list(name = mean))\n)\n\n<span style=\"color: #008080;\">#create boxplot to visualize results\n<\/span>boxplot(results, names=c(' <span style=\"color: #ff0000;\">Base R<\/span> ', ' <span style=\"color: #ff0000;\">dplyr<\/span> '))\n<\/strong><\/pre>\n<p><img decoding=\"async\" loading=\"lazy\" class=\"aligncenter wp-image-32184\" src=\"https:\/\/statorials.org\/wp-content\/uploads\/2023\/08\/micro1.jpg\" alt=\"O boxplot do pacote microbenchmark fornece R\" width=\"492\" height=\"448\" srcset=\"\" sizes=\"auto, \"><\/p>\n<p> <span style=\"color: #000000;\">Nos box plots, podemos ver que o m\u00e9todo dplyr leva mais tempo, em m\u00e9dia, para calcular o valor m\u00e9dio de pontos por equipe.<\/span><\/p>\n<p> <span style=\"color: #000000;\"><strong>Nota<\/strong> : Neste exemplo, usamos a fun\u00e7\u00e3o <strong>microbenchmark()<\/strong> para comparar o tempo de execu\u00e7\u00e3o de duas express\u00f5es diferentes, mas voc\u00ea pode comparar quantas express\u00f5es quiser na pr\u00e1tica.<\/span><\/p>\n<h2> <span style=\"color: #000000;\"><strong>Recursos adicionais<\/strong><\/span><\/h2>\n<p> <span style=\"color: #000000;\">Os tutoriais a seguir explicam como realizar outras tarefas comuns em R:<\/span><\/p>\n<p> <a href=\"https:\/\/statorials.org\/pt\/ambiente-claro-em-r\/\" target=\"_blank\" rel=\"noopener\">Como limpar o ambiente em R<\/a><br \/> <a href=\"https:\/\/statorials.org\/pt\/apagar-rastros-em-r\/\" target=\"_blank\" rel=\"noopener\">Como limpar todos os gr\u00e1ficos no RStudio<\/a><br \/> <a href=\"https:\/\/statorials.org\/pt\/carregar-varios-pacotes-em-r\/\" target=\"_blank\" rel=\"noopener\">Como carregar v\u00e1rios pacotes em R<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Voc\u00ea pode usar o pacote microbenchmark em R para comparar o tempo de execu\u00e7\u00e3o de diferentes express\u00f5es. Voc\u00ea pode usar a seguinte sintaxe para fazer isso: library (microbenchmark) #compare execution time of two different expressions microbenchmark( expression1, expression2) ) O exemplo a seguir mostra como usar essa sintaxe na pr\u00e1tica. Exemplo: Usando microbenchmark() em R [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[11],"tags":[],"class_list":["post-4029","post","type-post","status-publish","format-standard","hentry","category-guia"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v21.5 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>R: Como usar o pacote microbenchmark para medir o tempo de execu\u00e7\u00e3o - Estatologia<\/title>\n<meta name=\"description\" content=\"Este tutorial explica como usar o pacote microbenchmark em R para cronometrar o tempo que leva para executar v\u00e1rias fun\u00e7\u00f5es, incluindo exemplos.\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/statorials.org\/pt\/r-microbenchmark\/\" \/>\n<meta property=\"og:locale\" content=\"pt_PT\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"R: Como usar o pacote microbenchmark para medir o tempo de execu\u00e7\u00e3o - Estatologia\" \/>\n<meta property=\"og:description\" content=\"Este tutorial explica como usar o pacote microbenchmark em R para cronometrar o tempo que leva para executar v\u00e1rias fun\u00e7\u00f5es, incluindo exemplos.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/statorials.org\/pt\/r-microbenchmark\/\" \/>\n<meta property=\"og:site_name\" content=\"Statorials\" \/>\n<meta property=\"article:published_time\" content=\"2023-07-14T02:03:32+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/statorials.org\/wp-content\/uploads\/2023\/08\/micro1.jpg\" \/>\n<meta name=\"author\" content=\"Dr. benjamim anderson\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Escrito por\" \/>\n\t<meta name=\"twitter:data1\" content=\"Dr. benjamim anderson\" \/>\n\t<meta name=\"twitter:label2\" content=\"Tempo estimado de leitura\" \/>\n\t<meta name=\"twitter:data2\" content=\"3 minutos\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/statorials.org\/pt\/r-microbenchmark\/\",\"url\":\"https:\/\/statorials.org\/pt\/r-microbenchmark\/\",\"name\":\"R: Como usar o pacote microbenchmark para medir o tempo de execu\u00e7\u00e3o - Estatologia\",\"isPartOf\":{\"@id\":\"https:\/\/statorials.org\/pt\/#website\"},\"datePublished\":\"2023-07-14T02:03:32+00:00\",\"dateModified\":\"2023-07-14T02:03:32+00:00\",\"author\":{\"@id\":\"https:\/\/statorials.org\/pt\/#\/schema\/person\/e08f98e8db95e0aa9c310e1b27c9c666\"},\"description\":\"Este tutorial explica como usar o pacote microbenchmark em R para cronometrar o tempo que leva para executar v\u00e1rias fun\u00e7\u00f5es, incluindo exemplos.\",\"breadcrumb\":{\"@id\":\"https:\/\/statorials.org\/pt\/r-microbenchmark\/#breadcrumb\"},\"inLanguage\":\"pt-PT\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/statorials.org\/pt\/r-microbenchmark\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/statorials.org\/pt\/r-microbenchmark\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Lar\",\"item\":\"https:\/\/statorials.org\/pt\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"R: como usar o pacote microbenchmark para medir o tempo de execu\u00e7\u00e3o\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/statorials.org\/pt\/#website\",\"url\":\"https:\/\/statorials.org\/pt\/\",\"name\":\"Statorials\",\"description\":\"O seu guia para a literacia estat\u00edstica!\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/statorials.org\/pt\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"pt-PT\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/statorials.org\/pt\/#\/schema\/person\/e08f98e8db95e0aa9c310e1b27c9c666\",\"name\":\"Dr. benjamim anderson\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-PT\",\"@id\":\"https:\/\/statorials.org\/pt\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/statorials.org\/pt\/wp-content\/uploads\/2023\/10\/Dr.-Benjamin-Anderson-96x96.jpg\",\"contentUrl\":\"https:\/\/statorials.org\/pt\/wp-content\/uploads\/2023\/10\/Dr.-Benjamin-Anderson-96x96.jpg\",\"caption\":\"Dr. benjamim anderson\"},\"description\":\"Ol\u00e1, sou Benjamin, um professor aposentado de estat\u00edstica que se tornou professor dedicado na Statorials. Com vasta experi\u00eancia e conhecimento na \u00e1rea de estat\u00edstica, estou empenhado em compartilhar meu conhecimento para capacitar os alunos por meio de Statorials. Saber mais\",\"sameAs\":[\"https:\/\/statorials.org\/pt\"]}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"R: Como usar o pacote microbenchmark para medir o tempo de execu\u00e7\u00e3o - Estatologia","description":"Este tutorial explica como usar o pacote microbenchmark em R para cronometrar o tempo que leva para executar v\u00e1rias fun\u00e7\u00f5es, incluindo exemplos.","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/statorials.org\/pt\/r-microbenchmark\/","og_locale":"pt_PT","og_type":"article","og_title":"R: Como usar o pacote microbenchmark para medir o tempo de execu\u00e7\u00e3o - Estatologia","og_description":"Este tutorial explica como usar o pacote microbenchmark em R para cronometrar o tempo que leva para executar v\u00e1rias fun\u00e7\u00f5es, incluindo exemplos.","og_url":"https:\/\/statorials.org\/pt\/r-microbenchmark\/","og_site_name":"Statorials","article_published_time":"2023-07-14T02:03:32+00:00","og_image":[{"url":"https:\/\/statorials.org\/wp-content\/uploads\/2023\/08\/micro1.jpg"}],"author":"Dr. benjamim anderson","twitter_card":"summary_large_image","twitter_misc":{"Escrito por":"Dr. benjamim anderson","Tempo estimado de leitura":"3 minutos"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/statorials.org\/pt\/r-microbenchmark\/","url":"https:\/\/statorials.org\/pt\/r-microbenchmark\/","name":"R: Como usar o pacote microbenchmark para medir o tempo de execu\u00e7\u00e3o - Estatologia","isPartOf":{"@id":"https:\/\/statorials.org\/pt\/#website"},"datePublished":"2023-07-14T02:03:32+00:00","dateModified":"2023-07-14T02:03:32+00:00","author":{"@id":"https:\/\/statorials.org\/pt\/#\/schema\/person\/e08f98e8db95e0aa9c310e1b27c9c666"},"description":"Este tutorial explica como usar o pacote microbenchmark em R para cronometrar o tempo que leva para executar v\u00e1rias fun\u00e7\u00f5es, incluindo exemplos.","breadcrumb":{"@id":"https:\/\/statorials.org\/pt\/r-microbenchmark\/#breadcrumb"},"inLanguage":"pt-PT","potentialAction":[{"@type":"ReadAction","target":["https:\/\/statorials.org\/pt\/r-microbenchmark\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/statorials.org\/pt\/r-microbenchmark\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Lar","item":"https:\/\/statorials.org\/pt\/"},{"@type":"ListItem","position":2,"name":"R: como usar o pacote microbenchmark para medir o tempo de execu\u00e7\u00e3o"}]},{"@type":"WebSite","@id":"https:\/\/statorials.org\/pt\/#website","url":"https:\/\/statorials.org\/pt\/","name":"Statorials","description":"O seu guia para a literacia estat\u00edstica!","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/statorials.org\/pt\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"pt-PT"},{"@type":"Person","@id":"https:\/\/statorials.org\/pt\/#\/schema\/person\/e08f98e8db95e0aa9c310e1b27c9c666","name":"Dr. benjamim anderson","image":{"@type":"ImageObject","inLanguage":"pt-PT","@id":"https:\/\/statorials.org\/pt\/#\/schema\/person\/image\/","url":"https:\/\/statorials.org\/pt\/wp-content\/uploads\/2023\/10\/Dr.-Benjamin-Anderson-96x96.jpg","contentUrl":"https:\/\/statorials.org\/pt\/wp-content\/uploads\/2023\/10\/Dr.-Benjamin-Anderson-96x96.jpg","caption":"Dr. benjamim anderson"},"description":"Ol\u00e1, sou Benjamin, um professor aposentado de estat\u00edstica que se tornou professor dedicado na Statorials. Com vasta experi\u00eancia e conhecimento na \u00e1rea de estat\u00edstica, estou empenhado em compartilhar meu conhecimento para capacitar os alunos por meio de Statorials. Saber mais","sameAs":["https:\/\/statorials.org\/pt"]}]}},"yoast_meta":{"yoast_wpseo_title":"","yoast_wpseo_metadesc":"","yoast_wpseo_canonical":""},"_links":{"self":[{"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/posts\/4029","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/comments?post=4029"}],"version-history":[{"count":0,"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/posts\/4029\/revisions"}],"wp:attachment":[{"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/media?parent=4029"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/categories?post=4029"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/tags?post=4029"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}