<?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 Re: Compare Multiple Variables with Another Variable in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Compare-Multiple-Variables-with-Another-Variable/m-p/848225#M335351</link>
    <description>&lt;P&gt;Provide generic rules. Examples provided for specific patients do not provide a general rule that I could apply to other patients that do not have exactly the same values for the given variables.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;You might find the WHICHC function helpful. It will return the position of number of the first value if found in a list of values/variables.&lt;/P&gt;
&lt;PRE&gt;whichc (Plan_trt, of c(*)) &lt;/PRE&gt;
&lt;P&gt;would return the position of the value of Plan_trt if found in the array c or 0 if not found. So a 3 would mean that what ever value of Plan_trt may have was found in VIS5 given your array C definition.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Are the variables shown the only ones? I ask because the naming convention with VIS2 VIS4 VIS5 VIS6 VIS21 VIS51 VIS41 might indicate many missing variables such as VIS10 or VIS22 through VIS40.&lt;/P&gt;
&lt;P&gt;If they are the only variables then the "all" case may be easiest as&lt;/P&gt;
&lt;PRE&gt;if VIS2= VIS4= VIS5= VIS6= VIS21= VIS51= VIS41=Plan_TRT then Final_Actual_trt= Plan_trt ;&lt;/PRE&gt;
&lt;P&gt;But I am not sure that when you say "all" that I am interpreting that as you might intend.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Many users here don't want to download Excel files because of virus potential, others have such things blocked by security software. Also if you give us Excel we have to create a SAS data set and due to the non-existent constraints on Excel data cells the result we end up with may not have variables of the same type (numeric or character) and even values.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Instructions here: &lt;A href="https://communities.sas.com/t5/SAS-Communities-Library/How-to-create-a-data-step-version-of-your-data-AKA-generate/ta-p/258712" target="_blank"&gt;https://communities.sas.com/t5/SAS-Communities-Library/How-to-create-a-data-step-version-of-your-data-AKA-generate/ta-p/258712&lt;/A&gt; will show how to turn an existing SAS data set into data step code that can be pasted into a forum code box using the &amp;lt;/&amp;gt; icon or attached as text to show exactly what you have and that we can test code against.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
    <pubDate>Tue, 06 Dec 2022 23:45:47 GMT</pubDate>
    <dc:creator>ballardw</dc:creator>
    <dc:date>2022-12-06T23:45:47Z</dc:date>
    <item>
      <title>Compare Multiple Variables with Another Variable</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Compare-Multiple-Variables-with-Another-Variable/m-p/848208#M335346</link>
      <description>&lt;P&gt;Hi Experts,&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I am facing challenges with one of my activities. Please find below scenario and kindly provide the solution.&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;Input Table:&amp;nbsp;&lt;/STRONG&gt;&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Patient&lt;/TD&gt;&lt;TD&gt;Plan_TRT&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;ACT_TRT_VIS2&lt;/TD&gt;&lt;TD&gt;ACT_TRT_VIS4&lt;/TD&gt;&lt;TD&gt;ACT_TRT_VIS5&lt;/TD&gt;&lt;TD&gt;ACT_TRT_VIS6&lt;/TD&gt;&lt;TD&gt;ACT_TRT_VIS21&lt;/TD&gt;&lt;TD&gt;ACT_TRT_VIS51&lt;/TD&gt;&lt;TD&gt;ACT_TRT_VIS41&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;101&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;102&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 5MG&lt;/TD&gt;&lt;TD&gt;TRTB 10MG&lt;/TD&gt;&lt;TD&gt;TRTB 10MG&lt;/TD&gt;&lt;TD&gt;TRTB 10MG&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;103&lt;/TD&gt;&lt;TD&gt;TRTB 5MG&lt;/TD&gt;&lt;TD&gt;TRTB 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 5MG&lt;/TD&gt;&lt;TD&gt;TRTB 10MG&lt;/TD&gt;&lt;TD&gt;TRTB 10MG&lt;/TD&gt;&lt;TD&gt;TRTB 10MG&lt;/TD&gt;&lt;TD&gt;TRTB 10MG&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;104&lt;/TD&gt;&lt;TD&gt;PLACEBO&lt;/TD&gt;&lt;TD&gt;PLACEBO&lt;/TD&gt;&lt;TD&gt;PLACEBO&lt;/TD&gt;&lt;TD&gt;PLACEBO&lt;/TD&gt;&lt;TD&gt;PLACEBO&lt;/TD&gt;&lt;TD&gt;PLACEBO&lt;/TD&gt;&lt;TD&gt;PLACEBO&lt;/TD&gt;&lt;TD&gt;PLACEBO&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;105&lt;/TD&gt;&lt;TD&gt;TRTB 5MG&lt;/TD&gt;&lt;TD&gt;TRTB 5MG&lt;/TD&gt;&lt;TD&gt;TRTB 5MG&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;106&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 5MG&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&lt;STRONG&gt;Output Table Required: (FINAL_ACTUAL_TRT is required)&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Patient&lt;/TD&gt;&lt;TD&gt;Plan_TRT&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;ACT_TRT_VIS2&lt;/TD&gt;&lt;TD&gt;ACT_TRT_VIS4&lt;/TD&gt;&lt;TD&gt;ACT_TRT_VIS5&lt;/TD&gt;&lt;TD&gt;ACT_TRT_VIS6&lt;/TD&gt;&lt;TD&gt;ACT_TRT_VIS21&lt;/TD&gt;&lt;TD&gt;ACT_TRT_VIS51&lt;/TD&gt;&lt;TD&gt;ACT_TRT_VIS41&lt;/TD&gt;&lt;TD&gt;FINAL_ACTUAL_TRT&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;101&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;102&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 5MG&lt;/TD&gt;&lt;TD&gt;TRTB 10MG&lt;/TD&gt;&lt;TD&gt;TRTB 10MG&lt;/TD&gt;&lt;TD&gt;TRTB 10MG&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;TRTB 5MG&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;103&lt;/TD&gt;&lt;TD&gt;TRTB 5MG&lt;/TD&gt;&lt;TD&gt;TRTB 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 5MG&lt;/TD&gt;&lt;TD&gt;TRTB 10MG&lt;/TD&gt;&lt;TD&gt;TRTB 10MG&lt;/TD&gt;&lt;TD&gt;TRTB 10MG&lt;/TD&gt;&lt;TD&gt;TRTB 10MG&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;TRTB 5MG&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;104&lt;/TD&gt;&lt;TD&gt;PLACEBO&lt;/TD&gt;&lt;TD&gt;PLACEBO&lt;/TD&gt;&lt;TD&gt;PLACEBO&lt;/TD&gt;&lt;TD&gt;PLACEBO&lt;/TD&gt;&lt;TD&gt;PLACEBO&lt;/TD&gt;&lt;TD&gt;PLACEBO&lt;/TD&gt;&lt;TD&gt;PLACEBO&lt;/TD&gt;&lt;TD&gt;PLACEBO&lt;/TD&gt;&lt;TD&gt;PLACEBO&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;105&lt;/TD&gt;&lt;TD&gt;TRTB 5MG&lt;/TD&gt;&lt;TD&gt;TRTB 5MG&lt;/TD&gt;&lt;TD&gt;TRTB 5MG&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;TRTB 5MG&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;106&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 5MG&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;TD&gt;TRTA 10MG&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&lt;STRONG&gt;Conditions:&lt;/STRONG&gt;&amp;nbsp;&lt;/P&gt;&lt;OL&gt;&lt;LI&gt;&lt;STRONG&gt;It is for Patient 101&lt;/STRONG&gt; - If patient received Plan_TRT treatment at ACT_TRT_VIS2 and other Vists are blank then Fina_Actual_TRT value would be the value of ACT_TRT_VIS2 = &amp;nbsp;Plan_TRT &amp;nbsp;that is &amp;nbsp;“TRTA 10MG”&lt;/LI&gt;&lt;LI&gt;&lt;STRONG&gt;It is for Patient 102&lt;/STRONG&gt; - &amp;nbsp;If patient received Plan_TRT treatment at ACT_TRT_VIS2 (TRTA 10MG) but at ACT_TRT_VIS4 received a different treatment (TRTA 5MG) again at ACT_TRT_VIS5 switched back to ACT_TRT_VIS2 value and continued the same treatment for all the visits then FINAL_ACTUAL_TRT = Plan_TRT (TRTA 10MG)&lt;/LI&gt;&lt;LI&gt;&lt;STRONG&gt;It is for Patient 103&lt;/STRONG&gt; - If patient received different treatment than Plan_TRT (TRTA 10MG) at ACT_TRT_VIS2 (TRTB 5MG) and changes to Plan_TRT at VIS4 and again moved to &amp;nbsp;ACT_TRT_VIS2 value and continued to rest of visits with the same value then &amp;nbsp;FINAL_ACTUAL_TRT = &amp;nbsp;Plan_TRT &amp;nbsp;(that is “TRTB 5MG”).&lt;/LI&gt;&lt;LI&gt;&lt;STRONG&gt;It is for Patient 106&lt;/STRONG&gt; – If patient not received plan_TRT at ACT_TRT_VIS2 but later continued with Plan_TRT value then FINAL_ACTUAL_TRT = Plan_TRT (that is “TRTA 10MG”)&lt;/LI&gt;&lt;LI&gt;If patient received Plan_TRT for all then ACTUAL_TRT = Plan_TRT&lt;/LI&gt;&lt;/OL&gt;&lt;P&gt;I googled and trying to approach with below code. 1. Finding if all variables are have same values or not. If all records are having same values then planning to assign&amp;nbsp;&lt;STRONG&gt;FINAL_ACTUAL_TRT =&amp;nbsp;Plan_TRT .&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;data want;&lt;BR /&gt;set test3;&lt;BR /&gt;array c{*} $ VIS2 VIS4 VIS5 VIS6 VIS21 VIS51 VIS41;&lt;/P&gt;&lt;P&gt;if cmiss(of c{*})=0 then result='same';&lt;BR /&gt;else result='diff';&lt;/P&gt;&lt;P&gt;do I=2 to dim(c) while (result='same');&lt;BR /&gt;if c{i}^=c{i-1} then result='diff';&lt;BR /&gt;end;&lt;BR /&gt;run;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;OL&gt;&lt;LI&gt;If different values are there for visits then planning to take them to separate table and apply IF conditions. (But, I feel that is a lengthy approach.&amp;nbsp;&lt;/LI&gt;&lt;/OL&gt;&lt;P&gt;Requesting you to provide the better solution for me. Thanks you very much in advance for your support.&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Kind Regards,&lt;/P&gt;&lt;P&gt;RJ&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Tue, 06 Dec 2022 21:18:02 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Compare-Multiple-Variables-with-Another-Variable/m-p/848208#M335346</guid>
      <dc:creator>RJY9</dc:creator>
      <dc:date>2022-12-06T21:18:02Z</dc:date>
    </item>
    <item>
      <title>Re: Compare Multiple Variables with Another Variable</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Compare-Multiple-Variables-with-Another-Variable/m-p/848225#M335351</link>
      <description>&lt;P&gt;Provide generic rules. Examples provided for specific patients do not provide a general rule that I could apply to other patients that do not have exactly the same values for the given variables.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;You might find the WHICHC function helpful. It will return the position of number of the first value if found in a list of values/variables.&lt;/P&gt;
&lt;PRE&gt;whichc (Plan_trt, of c(*)) &lt;/PRE&gt;
&lt;P&gt;would return the position of the value of Plan_trt if found in the array c or 0 if not found. So a 3 would mean that what ever value of Plan_trt may have was found in VIS5 given your array C definition.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Are the variables shown the only ones? I ask because the naming convention with VIS2 VIS4 VIS5 VIS6 VIS21 VIS51 VIS41 might indicate many missing variables such as VIS10 or VIS22 through VIS40.&lt;/P&gt;
&lt;P&gt;If they are the only variables then the "all" case may be easiest as&lt;/P&gt;
&lt;PRE&gt;if VIS2= VIS4= VIS5= VIS6= VIS21= VIS51= VIS41=Plan_TRT then Final_Actual_trt= Plan_trt ;&lt;/PRE&gt;
&lt;P&gt;But I am not sure that when you say "all" that I am interpreting that as you might intend.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Many users here don't want to download Excel files because of virus potential, others have such things blocked by security software. Also if you give us Excel we have to create a SAS data set and due to the non-existent constraints on Excel data cells the result we end up with may not have variables of the same type (numeric or character) and even values.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Instructions here: &lt;A href="https://communities.sas.com/t5/SAS-Communities-Library/How-to-create-a-data-step-version-of-your-data-AKA-generate/ta-p/258712" target="_blank"&gt;https://communities.sas.com/t5/SAS-Communities-Library/How-to-create-a-data-step-version-of-your-data-AKA-generate/ta-p/258712&lt;/A&gt; will show how to turn an existing SAS data set into data step code that can be pasted into a forum code box using the &amp;lt;/&amp;gt; icon or attached as text to show exactly what you have and that we can test code against.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Tue, 06 Dec 2022 23:45:47 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Compare-Multiple-Variables-with-Another-Variable/m-p/848225#M335351</guid>
      <dc:creator>ballardw</dc:creator>
      <dc:date>2022-12-06T23:45:47Z</dc:date>
    </item>
  </channel>
</rss>

