]> hackdaworld.org Git - physik/nlsop.git/commitdiff
nearly finished gui code. adaptions / bugfixes.
authorhackbard <hackbard>
Thu, 4 Nov 2004 01:12:17 +0000 (01:12 +0000)
committerhackbard <hackbard>
Thu, 4 Nov 2004 01:12:17 +0000 (01:12 +0000)
nlsop.h
nlsop_client.c
nlsop_gui.c
nlsop_server.c

diff --git a/nlsop.h b/nlsop.h
index 5e8db78f4b1788865ff298ca9b2d638bebc616db..d41f84cc465552029d0ef72542aa24f1a3629c0d 100644 (file)
--- a/nlsop.h
+++ b/nlsop.h
@@ -15,9 +15,8 @@ typedef unsigned int u32;
 
 typedef struct __info
 {
- int cc,steps,range,diff_rate,cpi,s_rate;
- double s,b,c,dr_ac,dr_cc;
- char z_diff,c_diff;
+ int cc,steps,range,diff_rate,cpi,s_rate,save_rate;
+ double s,b,c,dr_ac;
 } info;
 
 #define AMORPH 1
@@ -34,7 +33,6 @@ typedef struct __info
 #define CC 0
 
 #define DR_AC .5
-#define DR_CC .2
 #define DIFF_RATE 1000
 
 #define S_D .00001
index 6467827129298eae329a196d15a04474a8e3e2c9..6ac9c92b36bd706fd231137e541ff87fa20a9814 100644 (file)
 #define MAKE_AMORPH(N) *(N)|=AMORPH
 #define MAKE_CRYST(N) *(N)&=~AMORPH
 
-#define NLSOP_CLIENT 'c'
-#define NLSOP_NJOB 'N'
-#define NLSOP_CJOB 'C'
-
 /* globals */
 
 char p_file[MAX_CHARS];
@@ -205,31 +201,29 @@ int distrib_c(d3_lattice *d3_l,info *my_info,int step,u32 rj_m,u32 *rj_g)
        }
       }
      }
-     if(my_info->z_diff)
+     /* diff in z direction */
+     if(k!=0)
      {
-      if(k!=0)
+      off=i+j*d3_l->max_x+(k-1)*d3_l->max_x*d3_l->max_y;
+      carry=0;
+      if(!*(d3_l->status+off)&AMORPH) carry=(int)(my_info->dr_ac*(*(d3_l->extra+off)));
+      if(carry!=0)
       {
-       off=i+j*d3_l->max_x+(k-1)*d3_l->max_x*d3_l->max_y;
-       carry=0;
-       if(!*(d3_l->status+off)&AMORPH) carry=(int)(my_info->dr_ac*(*(d3_l->extra+off)));
-       if(carry!=0)
-       {
-        *(d3_l->extra+off)-=carry;
-        *(d3_l->extra+offset)+=carry;
-       }
+       *(d3_l->extra+off)-=carry;
+       *(d3_l->extra+offset)+=carry;
       }
-      if(k!=d3_l->max_z-1)
+     }
+     if(k!=d3_l->max_z-1)
+     {
+      off=i+j*d3_l->max_x+(k+1)*d3_l->max_x*d3_l->max_y;
+      carry=0;
+      if(!*(d3_l->status+off)&AMORPH) carry=(int)(my_info->dr_ac*(*(d3_l->extra+off)));
+      if(carry!=0)
       {
-       off=i+j*d3_l->max_x+(k+1)*d3_l->max_x*d3_l->max_y;
-       carry=0;
-       if(!*(d3_l->status+off)&AMORPH) carry=(int)(my_info->dr_ac*(*(d3_l->extra+off)));
-       if(carry!=0)
-       {
-        *(d3_l->extra+off)-=carry;
-        *(d3_l->extra+offset)+=carry;
-       }
+       *(d3_l->extra+off)-=carry;
+       *(d3_l->extra+offset)+=carry;
       }
-     }  
+     }
     }
    } /* for z */
   } /* for y */
@@ -417,13 +411,11 @@ int get_data_and_calc(t_event *event,void *allineed) {
   u32 *nel_z;
   u32 x_c,y_c,z_c;
   int i,j;
-  int resave;
   int c_step;
   unsigned char data[256];
 
   t_net *net;
 
-  resave=RESAVE;
   c_step=0;
   ne_max=0;
   ip_max=0;
@@ -516,12 +508,12 @@ int get_data_and_calc(t_event *event,void *allineed) {
       process_cell(&d3_l,x_c,y_c,z_c,&my_info,nel_z[z_c]);
     }
     distrib_c(&d3_l,&my_info,i,ip_max,c_profile);
-    if(i%resave==0 && i!=0) {
+    i++;
+    if(i%my_info.save_rate==0) {
       dc=DC_OK;
       send_data(0);
       dc=DC_QUIT;
     }
-    i++;
     if(i%my_info.s_rate==0) sputter(&d3_l);
   }
 
index 7949c55558c5a56cfe1d1f6e32ba34fb04b2e1ab..0c56147ce2ba525925efea3ba6679635303c50ff 100644 (file)
@@ -75,6 +75,85 @@ int send_and_wait_for_answer(t_net *net,t_display *display) {
 
 int send_job(t_net *net,t_input *input,t_display *display) {
 
+  char command[MAX_CONTENT];
+  int x,y,z;
+  info info;
+
+  /* default values */
+  x=X;
+  y=Y;
+  z=Z;
+  info.cc=CC;
+  info.steps=STEPS;
+  info.range=RANGE;
+  info.diff_rate=DIFF_RATE;
+  info.cpi=CPI;
+  info.s_rate=S_RATE;
+  info.save_rate=RESAVE;
+  info.s=S_D;
+  info.b=B_D;
+  info.c=C_D;
+  info.dr_ac=DR_AC;
+
+  strncpy(command,input->content,MAX_CONTENT);
+
+  strtok(command," ");
+  while(strtok(NULL," ")!=NULL) {
+    switch(command[0]) {
+      case 'b':
+        info.b=atof(command+1);
+        break;
+      case 'c':
+        info.c=atof(command+1);
+        break;
+      case 's':
+        info.s=atof(command+1);
+        break;
+      case 'd':
+        info.diff_rate=atoi(command+1);
+        break;
+      case 'D':
+        info.dr_ac=atof(command+1);
+        break;
+      case 'S':
+        info.steps=atoi(command+1);
+        break;
+      case 'C':
+        info.cpi=atoi(command+1);
+        break;
+      case 'r':
+        info.range=atoi(command+1);
+        break;
+      case 'R':
+        info.s_rate=atoi(command+1);
+        break;
+      case 'x':
+        info.save_rate=atoi(command+1);
+        break;
+      case 'X':
+        x=atoi(command+1);
+        break;
+      case 'Y':
+        y=atoi(command+1);
+        break;
+      case 'Z':
+        z=atoi(command+1);
+        break;
+      default:
+        display_new_line(display,"unknown command");
+        break;
+    }
+  }
+
+  command[0]=GUI_ADDJOB;
+  network_send_chan(net,0,data,1);
+
+  network_send_chan(net,0,(unsigned char *)&x,sizeof(int));
+  network_send_chan(net,0,(unsigned char *)&y,sizeof(int));
+  network_send_chan(net,0,(unsigned char *)&z,sizeof(int));
+
+  network_send_chan(net,0,(unsigned char *)&info,sizeof(info));
+
   return 1;
 }
 
index 528c63465eb242d2ac54c51b1950881b11b192d9..5d11e484a312c7832b5ce93d21cb6fb00c6f3084 100644 (file)
@@ -122,10 +122,9 @@ int save_job(t_net *net,int channel,t_job *job,unsigned char dc) {
   if(ret==N_ERROR) printf("FATAL: getting step number failed\n");
 
   if(dc!=DC_QUIT) {
-    snprintf(filename,128,"nlsop_b%f_c%f_s%f_ds%d_dr%f_Z%c__%d_of_%d.save",
+    snprintf(filename,128,"./data/nlsop_b%f_c%f_s%f_ds%d_dr%f_-_%d_of_%d.save",
              job->info.b,job->info.c,job->info.s,
              job->info.diff_rate,job->info.dr_ac,
-             job->info.z_diff?'y':'n',
              job->step,job->info.steps);
     if((fd=open(filename,O_WRONLY|O_CREAT))<0) {
       printf("FATAL: unable to open file %s\n",filename);