ccs-sim
Version:
Modelling CCS systems
47 lines (46 loc) • 2.72 kB
JavaScript
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.defaultFluidConstructor = exports.createNewFluidConstructorFromLocalFiles = void 0;
const fluidDataFileReader_1 = require("./fluidDataFileReader");
const fluidProperties_1 = __importDefault(require("./fluidProperties"));
const phaseEnvelopeFileReader_1 = require("./phaseEnvelopeFileReader");
class Fluid {
constructor(pressure, temperature, flowrate, density, viscosity, enthalpy, entropy) {
this.pressure = pressure;
this.temperature = temperature;
this.flowrate = flowrate;
this.density = density;
this.viscosity = viscosity;
this.enthalpy = enthalpy;
this.entropy = entropy;
}
}
exports.default = Fluid;
const createNewFluidConstructorFromLocalFiles = (phaseFilePath = `${__dirname}/phaseEnvelope.csv`, fluidFilePath = `${__dirname}/co2lookup.csv`) => {
const phaseData = new phaseEnvelopeFileReader_1.PhaseEnvelopeFileReader(phaseFilePath);
const fluidData = new fluidDataFileReader_1.FluidDataFileReader(fluidFilePath);
const properties = new fluidProperties_1.default(phaseData, fluidData);
return (pressure, temperature, flowrate) => __awaiter(void 0, void 0, void 0, function* () {
const [density, viscosity, enthalpy, entropy] = [
yield properties.density(pressure, temperature),
yield properties.viscosity(pressure, temperature),
yield properties.enthalpy(pressure, temperature),
yield properties.entropy(pressure, temperature),
];
return new Fluid(pressure, temperature, flowrate, density, viscosity, enthalpy, entropy);
});
};
exports.createNewFluidConstructorFromLocalFiles = createNewFluidConstructorFromLocalFiles;
exports.defaultFluidConstructor = exports.createNewFluidConstructorFromLocalFiles();
;