10
0
mirror of https://github.com/LCPQ/QUESTDB_website.git synced 2024-07-04 02:16:11 +02:00
QUESTDB_website/static/scripts/data.js

156 lines
3.8 KiB
JavaScript
Raw Normal View History

2019-08-28 11:59:18 +02:00
class code {
constructor(name,version){
2019-09-03 15:36:32 +02:00
this.name=name;
this.version=version;
};
toString() {
var str=this.name;
if (this.version) {
str=str+' ('+this.version+')';
}
return str;
2019-08-28 11:59:18 +02:00
}
}
2019-09-17 17:19:00 +02:00
class method {
constructor(name,basis){
2019-09-03 15:36:32 +02:00
this.name=name;
2019-09-17 17:19:00 +02:00
this.basis=basis;
2019-09-03 15:36:32 +02:00
}
toString() {
var str=this.name;
2019-09-17 17:19:00 +02:00
if (this.name) {
str=str+'/'+this.basis;
2019-09-03 15:36:32 +02:00
}
return str;
2019-08-22 10:34:07 +02:00
}
}
2019-09-16 11:57:52 +02:00
class geometry {
2019-09-17 17:19:00 +02:00
constructor(symetry,method){
this.symetry=method
this.symetry=method
2019-09-16 11:57:52 +02:00
}
2019-09-17 17:19:00 +02:00
toString(){
return String.raw `${this.symetry}-${this.method}`
2019-09-16 11:57:52 +02:00
}
}
2019-08-22 10:34:07 +02:00
2019-08-28 11:59:18 +02:00
class state{
2019-09-17 17:19:00 +02:00
constructor(number,multiplicity,symetry,geometry){
2019-08-28 11:59:18 +02:00
this.number=number;
this.multiplicity=multiplicity;
this.symetry=symetry;
2019-09-17 17:19:00 +02:00
this.geometry=geometry
2019-09-03 15:36:32 +02:00
};
toString() {
var str=this.number+ ' ^'+this.multiplicity+this.symetry;
return str;
};
toLaTeX() {
2019-09-03 15:38:17 +02:00
var tex= String.raw`${this.number}\:\vphantom{\mathrm{${this.symetry.charAt(0)}}}^{${this.multiplicity}}\mathrm{${this.symetry}}`;
2019-09-03 15:36:32 +02:00
return tex;
};
2019-08-22 10:34:07 +02:00
}
2019-08-28 11:59:18 +02:00
class doi{
constructor(doistring){
this.string=doistring
2019-09-03 15:36:32 +02:00
};
toString() {
return this.string;
};
2019-08-28 11:59:18 +02:00
get url() {
2019-09-03 15:36:32 +02:00
return 'https://doi.org/'+this.string;
};
2019-08-28 11:59:18 +02:00
}
class excitation{
2019-09-02 09:34:43 +02:00
constructor(start,end,Eabs){
2019-08-28 11:59:18 +02:00
this.start=start;
this.end=end;
2019-09-02 09:34:43 +02:00
this.Eabs=Eabs;
2019-08-28 11:59:18 +02:00
}
2019-09-03 15:36:32 +02:00
toString() {
2019-09-09 10:32:51 +02:00
return this.start+ ', ' + this.end +', '+ this.Eabs.toPrecision(3);
2019-09-03 15:36:32 +02:00
}
2019-08-28 11:59:18 +02:00
}
class data {
constructor(){
2019-09-03 15:36:32 +02:00
this.title='';
2019-08-28 11:59:18 +02:00
this.code=null;
2019-09-17 17:19:00 +02:00
this.ZPE=null;
2019-09-16 09:47:57 +02:00
this.method=null;
2019-08-28 11:59:18 +02:00
this.doi=null;
this.excitations=[];
}
static async loadAsync(file) {
2019-09-09 15:15:39 +02:00
return data.loadString(await getTextFromFileAsync(getFullDataPath(file)));
2019-08-28 11:59:18 +02:00
}
2019-09-05 10:32:46 +02:00
static loadString(text) {
2019-08-28 11:59:18 +02:00
// for each line with metadata
var ismetaArea=true;
//metadata RegExp (start with #; maybe somme spaces; : ; maybe somme space; datas)
var meta=/^#\s*([A-Za-z]+)\s*:\s*(.*)$/;
var dat=new data();
function readmeta(line){
// get key value
var match=line.match(meta);
// normalize key to lower
var key=match[1].toLowerCase();
//if data has value
if(match.length==3 && match[2]) {
var val=match[2];
switch(key) {
case "title":
dat.title=val;
break;
case "code":
var vals=val.split(",")
if(vals.length>=2){
dat.code=new code(vals[0],vals[1]);
} else {
dat.code=new code(vals[0],null);
}
break;
2019-09-16 09:47:57 +02:00
case "method":
2019-09-17 17:19:00 +02:00
var vals=val.split(",")
dat.method=new method(vals[0],vals[1]);
break;
case "zpe":
var vals=val.split(",")
dat.ZPE=new method(vals[0],vals[1]);
break;
2019-08-28 11:59:18 +02:00
case "doi":
dat.doi=new doi(val);
break;
}
}
}
function readrow(line){
2019-09-17 17:19:00 +02:00
var vals=line.split(/\s+/);
var geom=vals[3].split(",")
var start=new state(parseInt(vals[0],10),parseInt(vals[1],10),vals[2], new geometry(geom[0],new method(geom[1],geom[2])));
geom=vals[7].split(",")
var end=new state(parseInt(vals[4],10),vals[5],vals[6], new geometry(geom[0],new method(geom[1],geom[2])));
var ex=new excitation(start,end,parseFloat(vals[8],10));
2019-08-28 11:59:18 +02:00
dat.excitations.push(ex);
};
text.split("\n").forEach(function(line) {
//if it's not empty line
line=line.trim();
if (line){
//if # may be metadata or comment
if (line.charAt(0)=="#") {
//if it's metadata
if(ismetaArea && meta.test(line)) {
readmeta(line);
}
} else { //else its row
ismetaArea=false;
readrow(line);
}
}
});
return dat
}
2019-08-22 10:34:07 +02:00
}