<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Threads in proc ds2 in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Threads-in-proc-ds2/m-p/494419#M130275</link>
    <description>&lt;P&gt;Hi,&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;I am creating threads in a proc ds2 like the above example.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;My question is:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;when I execute this in a single node, the threads are executed in differents CPUs&lt;/P&gt;
&lt;P&gt;when I execute this in a Hadoop cluster with several nodes, each thread is executed in a different node,&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Is this correct????&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Thanks in advance&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc ds2; 
thread tabsas2.my_thread/overwrite=yes;
	dcl int reg ;  /* declaracion vars */
	method init(); /* metodo init solo se ejecuta una vez al inicio */
		put 'inicio';
	end;
	/* metodo definido por el usuario */
	method calculo(int varin) returns int;
		varout = varin*2;
		return varout;
    end;
	method run(); /* metodo run se ejecuta de forma iteratica */
		set test; 
		hc_consumo2=calculo(hc_consumo);
		reg+1;
	end;
	method term(); /* metodo term se ejecuta solo una vez al final */
		put 'fin.' 'hilo:' _threadid_ 'Num reg:' reg;
	end;
endthread;
run; 
quit;

/* Llamada al hilo creado */

proc ds2;
data tabsas2.res_thread/overwrite=yes;
dcl thread tabsas2.my_thread thread_object();

method run();
    set from thread_object threads = 4;
end;
enddata;
run; quit;&lt;/CODE&gt;&lt;/PRE&gt;</description>
    <pubDate>Tue, 11 Sep 2018 08:41:41 GMT</pubDate>
    <dc:creator>juanvg1972</dc:creator>
    <dc:date>2018-09-11T08:41:41Z</dc:date>
    <item>
      <title>Threads in proc ds2</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Threads-in-proc-ds2/m-p/494419#M130275</link>
      <description>&lt;P&gt;Hi,&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;I am creating threads in a proc ds2 like the above example.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;My question is:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;when I execute this in a single node, the threads are executed in differents CPUs&lt;/P&gt;
&lt;P&gt;when I execute this in a Hadoop cluster with several nodes, each thread is executed in a different node,&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Is this correct????&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Thanks in advance&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc ds2; 
thread tabsas2.my_thread/overwrite=yes;
	dcl int reg ;  /* declaracion vars */
	method init(); /* metodo init solo se ejecuta una vez al inicio */
		put 'inicio';
	end;
	/* metodo definido por el usuario */
	method calculo(int varin) returns int;
		varout = varin*2;
		return varout;
    end;
	method run(); /* metodo run se ejecuta de forma iteratica */
		set test; 
		hc_consumo2=calculo(hc_consumo);
		reg+1;
	end;
	method term(); /* metodo term se ejecuta solo una vez al final */
		put 'fin.' 'hilo:' _threadid_ 'Num reg:' reg;
	end;
endthread;
run; 
quit;

/* Llamada al hilo creado */

proc ds2;
data tabsas2.res_thread/overwrite=yes;
dcl thread tabsas2.my_thread thread_object();

method run();
    set from thread_object threads = 4;
end;
enddata;
run; quit;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Tue, 11 Sep 2018 08:41:41 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Threads-in-proc-ds2/m-p/494419#M130275</guid>
      <dc:creator>juanvg1972</dc:creator>
      <dc:date>2018-09-11T08:41:41Z</dc:date>
    </item>
    <item>
      <title>Re: Threads in proc ds2</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Threads-in-proc-ds2/m-p/494674#M130400</link>
      <description>&lt;P&gt;I read a bit about&amp;nbsp;this topic out of interest, but never actually had a chance to try myself, so take my reply with a HUGE pinch of salt.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;EM&gt;1. when I execute this in a single node, the threads are executed in different CPUs&lt;/EM&gt;&lt;/P&gt;
&lt;P&gt;The OS decides where the threads go, but this is the best approximation of the typical behaviour&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;EM&gt;2. when I execute this in a Hadoop cluster with several nodes, each thread is executed in a different node,&amp;nbsp;&lt;/EM&gt;&lt;/P&gt;
&lt;P&gt;As I understand it, the only ways you could have multiple threads in Hadoop is if either:&lt;/P&gt;
&lt;P&gt;1- proc ds2 sends several queries to the database (option&amp;nbsp;&lt;FONT face="courier new,courier"&gt;sastrace = ',,,d'&lt;/FONT&gt;&amp;nbsp;doesn't seem to monitor this connection), somehow telling it&amp;nbsp;to only process a non-overlapping subset of the data in each query.&lt;/P&gt;
&lt;P&gt;2- You have in-database licensed and installed&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Tue, 11 Sep 2018 23:20:05 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Threads-in-proc-ds2/m-p/494674#M130400</guid>
      <dc:creator>ChrisNZ</dc:creator>
      <dc:date>2018-09-11T23:20:05Z</dc:date>
    </item>
  </channel>
</rss>

