<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://ascend4.org/index.php?action=history&amp;feed=atom&amp;title=User%3AKarthik0112358%2Fmassmatrix</id>
	<title>User:Karthik0112358/massmatrix - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://ascend4.org/index.php?action=history&amp;feed=atom&amp;title=User%3AKarthik0112358%2Fmassmatrix"/>
	<link rel="alternate" type="text/html" href="https://ascend4.org/index.php?title=User:Karthik0112358/massmatrix&amp;action=history"/>
	<updated>2026-04-28T23:28:54Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.43.6</generator>
	<entry>
		<id>https://ascend4.org/index.php?title=User:Karthik0112358/massmatrix&amp;diff=2689&amp;oldid=prev</id>
		<title>Karthik0112358: Created page with &#039;&lt;source lang=&quot;c&quot;&gt; //Include necessary headers. int massmatrix(slv_system_t sys,  struct massmatrixStruct *mass, const rel_filter_t *rfilter, const var_filter_t *vfilter){ // here…&#039;</title>
		<link rel="alternate" type="text/html" href="https://ascend4.org/index.php?title=User:Karthik0112358/massmatrix&amp;diff=2689&amp;oldid=prev"/>
		<updated>2011-06-22T03:14:53Z</updated>

		<summary type="html">&lt;p&gt;Created page with &amp;#039;&amp;lt;source lang=&amp;quot;c&amp;quot;&amp;gt; //Include necessary headers. int massmatrix(slv_system_t sys,  struct massmatrixStruct *mass, const rel_filter_t *rfilter, const var_filter_t *vfilter){ // here…&amp;#039;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;&amp;lt;source lang=&amp;quot;c&amp;quot;&amp;gt;&lt;br /&gt;
//Include necessary headers.&lt;br /&gt;
int massmatrix(slv_system_t sys,  struct massmatrixStruct *mass, const rel_filter_t *rfilter, const var_filter_t *vfilter){&lt;br /&gt;
// here there might be some more parameters to accept. I haven&amp;#039;t figured it out yet. Although I think some filter parameters need to be shaken up a little.&lt;br /&gt;
   struct var_variable **svars;&lt;br /&gt;
   struct rel_relation **srels;&lt;br /&gt;
   mtx_coord_t coord;&lt;br /&gt;
//the above declarations are self explanatory.&lt;br /&gt;
   int i,j,n,nsr,nsv,nr,nv;&lt;br /&gt;
//first count the rels&lt;br /&gt;
   nsr = slv_get_num_solvers_rels(sys);&lt;br /&gt;
   nr = slv_count_solvers_rels(sys,rfilter);&lt;br /&gt;
   srels = slv_get_solvers_rel_list(sys);&lt;br /&gt;
//and vars&lt;br /&gt;
   nsv = slv_get_num_solvers_vars(sys);&lt;br /&gt;
   nv = slv_count_solvers_vars(sys,vfilter);&lt;br /&gt;
   svars = slv_get_solvers_var_list(sys);&lt;br /&gt;
//allocate space for lists&lt;br /&gt;
   mass-&amp;gt;vars = ASC_NEW_ARRAY(struct var_variable*, nv);&lt;br /&gt;
   mass-&amp;gt;rels = ASC_NEW_ARRAY(struct rel_relation*, nr);&lt;br /&gt;
   vartocol = ASC_NEW_ARRAY(int,nsv);&lt;br /&gt;
//So till here code looks neat. Gets slightly messy from now on.&lt;br /&gt;
//now create a the lists of vars and rels, and temp mapping array&lt;br /&gt;
   n = 0;&lt;br /&gt;
   for(i=0;i&amp;lt;nsr;++i){&lt;br /&gt;
      if(rel_apply_filter(srels[i],rfilter)){&lt;br /&gt;
         mass-&amp;gt;rels[n++] = srels[i];&lt;br /&gt;
      }&lt;br /&gt;
   }&lt;br /&gt;
   asc_assert(n==nr);&lt;br /&gt;
   n = 0;&lt;br /&gt;
   for(i=0;i&amp;lt;nsv;++i){&lt;br /&gt;
      if(var_apply_filter(svars[i],vfilter)){         &lt;br /&gt;
         vartocol[i]=n;&lt;br /&gt;
         mass-&amp;gt;vars[n++] = svars[i];&lt;br /&gt;
      }else{&lt;br /&gt;
         vartocol[i]=-1;&lt;br /&gt;
      }&lt;br /&gt;
   }&lt;br /&gt;
   asc_assert(n==nv);&lt;br /&gt;
//now create a matrix&lt;br /&gt;
   mass-&amp;gt;M = mtx_create();&lt;br /&gt;
   mtx_set_order(mass-&amp;gt;M, MAX(nv,nr));&lt;br /&gt;
   for(i=0;i&amp;lt;nr;++i){&lt;br /&gt;
//Need to write a function, so that I can call it here which basically takes the relation and finds the coefficients of all first order derivatives. &lt;br /&gt;
      for(j=0;j&amp;lt;n;++j){&lt;br /&gt;
         mtx_set_value(mass-&amp;gt;M,mtx_coord(&amp;amp;coord,i,vartocol[/* need to figure equivalent here*/]),/*put the equivalent figured here too*/);&lt;br /&gt;
      }&lt;br /&gt;
//Check for errors in doing above 2 operations via function call&lt;br /&gt;
   }&lt;br /&gt;
   mass-&amp;gt;n_rels = nr;&lt;br /&gt;
   mass-&amp;gt;n_vars = nv;&lt;br /&gt;
}&lt;br /&gt;
/*&lt;br /&gt;
I would define the structure massmatrix in the header as:&lt;br /&gt;
struct massmatrixStruct{&lt;br /&gt;
   mtx_matrix_t M;&lt;br /&gt;
   struct rel_relation **rels;&lt;br /&gt;
   struct var_variable **vars;&lt;br /&gt;
   int n_rels, n_vars;&lt;br /&gt;
}; &lt;br /&gt;
*/&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Karthik0112358</name></author>
	</entry>
</feed>