Newer
Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
// Amira Abdel-Rahman
// (c) Massachusetts Institute of Technology 2020
const { exec } = require("child_process");
var express = require('express');
var fs = require('fs');
var app = express();
var path = require('path');
var setup,cmods;
// will parse incoming JSON data and convert it into an object literal for you
app.use(express.json({limit: '50mb', extended: true}));
app.use(express.urlencoded({limit: '50mb', extended: true}));
//serve the html
app.use(express.static(__dirname + '/../')); // exposes index.html, per below
app.post("/", function(req, res) {
// each key in req.body will match the keys in the data object that you passed in
var myObject = req.body.data;
setup=JSON.parse(myObject.foo);
cmods=setup.cmods;
if(setup.run){
console.log("run CMODS!");
runCMODS();
}else{
console.log("reading data");
}
// console.log(setup);
// myObject.foo === "bar"
res.send("I am done");
});
port = 8080;
app.listen(port);
console.log(`Open http://localhost:${port}/demos/indexCMODS.html in your browser`);
function runCMODS(){
var STL_particles_command_old= "./STL_particles "+cmods.STL_particles.nlattice+" < "+cmods.STL_particles.stlName+".stl";
var particles_bonds_command_old= " | ./particles_bonds "+cmods.particles_bonds.grid+" "+cmods.particles_bonds.block+"";
var bonds_stress_strain_command1_old= " | ./bonds_stress_strain1 "+cmods.bonds_stress_strain.grid+" "+cmods.bonds_stress_strain.block+" "+cmods.bonds_stress_strain.spring+" "
+cmods.bonds_stress_strain.mass+" "+cmods.bonds_stress_strain.dissipation
+" "+cmods.bonds_stress_strain.dt+" "+cmods.bonds_stress_strain.nloop
+" "+cmods.bonds_stress_strain.fraction+" "+cmods.bonds_stress_strain.fraction+" "+cmods.bonds_stress_strain.step
+" "+cmods.bonds_stress_strain.bond+"";
var bonds_stress_strain_command_old= " | ./bonds_stress_strain "+cmods.bonds_stress_strain.grid+" "+cmods.bonds_stress_strain.block+" "+cmods.bonds_stress_strain.spring+" "
+cmods.bonds_stress_strain.mass+" "+cmods.bonds_stress_strain.dissipation
+" "+cmods.bonds_stress_strain.dt+" "+cmods.bonds_stress_strain.nloop
+" "+cmods.bonds_stress_strain.fraction+" "+cmods.bonds_stress_strain.step
+" "+cmods.bonds_stress_strain.bond+"";
var strain_GL_command_old= " | ./strain_GL "+cmods.strain_GL.size+" "+cmods.strain_GL.scale+" "+cmods.strain_GL.rx+" "+cmods.strain_GL.ry+" "+cmods.strain_GL.rz+" "+cmods.strain_GL.sxyz+" "+cmods.strain_GL.perspective+"";
var STL_particles_command= "./STL_particles nlattice="+cmods.STL_particles.nlattice+" < "+cmods.STL_particles.stlName+".stl";
var particles_bonds_command= " | ./particles_bonds grid="+cmods.particles_bonds.grid+" block="+cmods.particles_bonds.block+"";
var bonds_stress_strain_command_= " | ./bonds_stress_strain grid="+cmods.bonds_stress_strain.grid+" block="+cmods.bonds_stress_strain.block+" spring="+cmods.bonds_stress_strain.spring
+" mass="+cmods.bonds_stress_strain.mass+" dissipation="+cmods.bonds_stress_strain.dissipation
+" dt="+cmods.bonds_stress_strain.dt+" loop="+cmods.bonds_stress_strain.nloop+" step="+cmods.bonds_stress_strain.step
+" bond="+cmods.bonds_stress_strain.bond+"";
var bonds_stress_strain_command= " | ./bonds_stress_strain2 grid="+cmods.bonds_stress_strain.grid+" block="+cmods.bonds_stress_strain.block+" spring="+cmods.bonds_stress_strain.spring
+" mass="+cmods.bonds_stress_strain.mass+" dissipation="+cmods.bonds_stress_strain.dissipation
+" dt="+cmods.bonds_stress_strain.dt+" loop="+cmods.bonds_stress_strain.nloop+" step="+cmods.bonds_stress_strain.step
+" bond="+cmods.bonds_stress_strain.bond+"";
bonds_stress_strain_command+=" load="+cmods.bonds_stress_strain.load.type+" percent="+cmods.bonds_stress_strain.load.percent;
}else if(cmods.bonds_stress_strain.load.type=="ycylinder"){
bonds_stress_strain_command+=" load="+cmods.bonds_stress_strain.load.type
+" xmin="+cmods.bonds_stress_strain.load.cx.min+" zmin="+cmods.bonds_stress_strain.load.cz.min+" rmin="+cmods.bonds_stress_strain.load.cr.min
+" xmax="+cmods.bonds_stress_strain.load.cx.max+" zmax="+cmods.bonds_stress_strain.load.cz.max+" rmax="+cmods.bonds_stress_strain.load.cr.max;
}else if(cmods.bonds_stress_strain.load.type=="loadbox"){
bonds_stress_strain_command+=" load="+cmods.bonds_stress_strain.load.type
+" lxmin="+cmods.bonds_stress_strain.load.lmin.x+" lymin="+cmods.bonds_stress_strain.load.lmin.z+" lxmin="+cmods.bonds_stress_strain.load.lmin.y
+" lxmax="+cmods.bonds_stress_strain.load.lmax.x+" lymax="+cmods.bonds_stress_strain.load.lmax.z+" lxmax="+cmods.bonds_stress_strain.load.lmax.y
+" sxmin="+cmods.bonds_stress_strain.load.smin.x+" symin="+cmods.bonds_stress_strain.load.smin.z+" sxmin="+cmods.bonds_stress_strain.load.smin.y
+" sxmax="+cmods.bonds_stress_strain.load.smax.x+" symax="+cmods.bonds_stress_strain.load.smax.z+" sxmax="+cmods.bonds_stress_strain.load.smax.y;
}
var strain_GL_command= " | ./strain_GL size="+cmods.strain_GL.size+" scale="+cmods.strain_GL.scale+" rx="+cmods.strain_GL.rx+" ry="+cmods.strain_GL.ry+" rz="+cmods.strain_GL.rz+" sxyz="+cmods.strain_GL.sxyz+" perspective="+cmods.strain_GL.perspective+"";
var command= STL_particles_command+ particles_bonds_command+bonds_stress_strain_command +strain_GL_command;
console.log(command)
// var command= "./STL_particles 100 < "+stlName+".stl | ./particles_bonds 1024 1024 | ./bonds_stress_strain 512 512 30000000 1 100 0.0001 1000 0.04 -0.0002 15 | ./strain_GL 1.5 200 1.55 0. -0.0 0.25 0.05";
exec(command, (error, stdout, stderr) => {
if (error) {
console.log(`error: ${error.message}`);
return;
}
if (stderr) {
console.log(`stderr: ${stderr}`);
return;
}
console.log(`stdout: ${stdout}`);
});
}