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
|
|
|
}
|
|
|
|
}
|
|
|
|
class basis {
|
|
|
|
constructor(name,type){
|
2019-09-03 15:36:32 +02:00
|
|
|
this.name=name;
|
|
|
|
this.type=type;
|
|
|
|
}
|
|
|
|
toString() {
|
|
|
|
var str=this.name;
|
|
|
|
if (this.type) {
|
|
|
|
str=str+' ('+this.type+')';
|
|
|
|
}
|
|
|
|
return str;
|
2019-08-22 10:34:07 +02:00
|
|
|
}
|
|
|
|
}
|
2019-09-16 11:57:52 +02:00
|
|
|
class geometry {
|
|
|
|
constructor(method,basis){
|
|
|
|
this.method=method
|
|
|
|
this.basis=basis
|
|
|
|
}
|
|
|
|
toString() {
|
|
|
|
var str=this.method;
|
|
|
|
if (this.basis) {
|
|
|
|
str=str+'/'+this.basis.name;
|
|
|
|
}
|
|
|
|
return str;
|
|
|
|
}
|
|
|
|
}
|
2019-08-22 10:34:07 +02:00
|
|
|
|
2019-08-28 11:59:18 +02:00
|
|
|
class state{
|
|
|
|
constructor(number,multiplicity,symetry){
|
|
|
|
this.number=number;
|
|
|
|
this.multiplicity=multiplicity;
|
|
|
|
this.symetry=symetry;
|
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-16 11:57:52 +02:00
|
|
|
this.geometry=null;
|
2019-09-16 09:47:57 +02:00
|
|
|
this.method=null;
|
2019-08-28 11:59:18 +02:00
|
|
|
this.basis=null;
|
|
|
|
this.doi=null;
|
|
|
|
this.excitations=[];
|
|
|
|
}
|
2019-09-05 11:31:38 +02:00
|
|
|
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 11:57:52 +02:00
|
|
|
case "geometry":
|
|
|
|
var vals=val.split(",")
|
|
|
|
switch(vals.length){
|
|
|
|
case 1:
|
|
|
|
dat.geometry=new geometry(vals[0],null);
|
|
|
|
break;
|
|
|
|
case 2:
|
|
|
|
dat.geometry=new geometry(vals[0],new basis(vals[1],null));
|
|
|
|
break;
|
|
|
|
case 3:
|
|
|
|
dat.geometry=new geometry(vals[0],new basis(vals[1],vals[2]));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
2019-09-16 09:47:57 +02:00
|
|
|
case "method":
|
|
|
|
dat.method=val;
|
|
|
|
break;
|
2019-08-28 11:59:18 +02:00
|
|
|
case "basis":
|
|
|
|
var vals=val.split(",")
|
|
|
|
if(vals.length>=2){
|
|
|
|
dat.basis=new basis(vals[0],vals[1])
|
|
|
|
} else {
|
|
|
|
dat.basis=new basis(vals[0],null);
|
|
|
|
}
|
2019-09-16 09:47:57 +02:00
|
|
|
break;
|
2019-08-28 11:59:18 +02:00
|
|
|
case "doi":
|
|
|
|
dat.doi=new doi(val);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
function readrow(line){
|
|
|
|
var vals=line.split(/\s+/);
|
2019-09-02 09:29:57 +02:00
|
|
|
var start=new state(parseInt(vals[0],10),parseInt(vals[1],10),vals[2]);
|
|
|
|
var end=new state(parseInt(vals[3],10),vals[4],vals[5]);
|
|
|
|
var ex=new excitation(start,end,parseFloat(vals[6],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
|
|
|
}
|