-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcalculations.m
61 lines (52 loc) · 3.51 KB
/
calculations.m
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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
loadRandStream(simulation.randCheck,simulation.randStreamName)
%set up some simulation factors
simulation.grainVolume = (simulation.grainLength)^2;
%sun
[sun.widthAngle sun.lengthAngle sun.daytime sun.positionVector] = SunAngles(location.time,location.date,location.latitude,location.longitude,location.timezoneLongitude,trough.bearing);
sun.fullQuantization = 2*sun.halfQuantization + 1;
sun.irradiance = setValueStructField(sun,'irradiance',SolarIntensity(location)); %W/m^2
%atmosphere
atmosphere.temperature = setValueStructField(atmosphere,'temperature',AmbientTemperature(location));
atmosphere.windSpeed = setValueStructField(atmosphere,'windSpeed',WindSpeed(location));
atmosphere.pressure = setValueStructField(atmosphere,'pressure',atm2bar(1));
%compute trough stuff
trough.rotAngle = deg2rad(sun.widthAngle) + trough.trackingError;
trough.height = ParabolaHeight(trough.focalLength,trough.width);
% trough.rimAngle = ParabolaRimAngle(trough.focalLength, trough.width);
trough.arcLength = ParabolaArcLength(trough.focalLength,trough.width);
trough.area = trough.arcLength*trough.length;
trough.aperature = trough.width*trough.length;
trough.coordinates = ParabolaCoordinates(trough, simulation);
trough.gradients = ParabolaGradient(trough.coordinates,trough.surfaceStdDev);
trough.coordinates = trough.coordinates(:,2:end-1); %throw away the coordinates no longer needed
% trough.fullQuantization = 2*trough.halfQuantization + 1;
% if trough.halfQuantization == 0; trough.specularity = 1; end;
trough.normals = normalize([-trough.gradients(1,:); ones(1,length(trough.gradients)); -trough.gradients(2,:)]);
trough.reflector.length = trough.length;
trough.reflector.width = trough.arcLength;
trough.reflector.material = trough.material;
%compute receiver stuff
receiver.absorber.innerDiameter = receiver.absorber.diameter - receiver.absorber.thickness; %m
receiver.absorber.outerDiameter = receiver.absorber.diameter; %m
receiver.sleeve.innerDiameter = receiver.sleeve.diameter - receiver.sleeve.thickness; %m
receiver.sleeve.outerDiameter = receiver.sleeve.diameter; %m
receiver.radius = receiver.absorber.outerDiameter/2;
receiver.length = trough.length + receiver.extraLength; %m
receiver.absorber.length = receiver.length; %m
receiver.sleeve.length = receiver.length; %m
receiver.position = trough.focusCoordinates + receiver.mislocation;
receiver.coordinates = RecieverCoordinates(receiver, simulation);
receiver.gradients = ReceiverGradient(receiver.coordinates,receiver.surfaceStdDev);
receiver.nBrackets = ceil(receiver.length/receiver.bracketSpacing);
%Collector Cycle
collectorCycle.inletTemperature = setValueStructField(collectorCycle,'inletTemperature', atmosphere.temperature);
collectorCycle.outletTemperature = setValueStructField(collectorCycle,'outletTemperature', atmosphere.temperature);
collectorCycle.area = pi*(receiver.absorber.innerDiameter^2 - receiver.annulus.diameter^2)/4;
collectorCycle.speed = fluidSpeed(collectorCycle.flowRate,receiver.absorber.innerDiameter,collectorCycle.fluid.density,receiver.annulusCheck,receiver.annulus.diameter);
collectorCycle.massFlowRate = collectorCycle.flowRate*materialProperty(collectorCycle.fluid.densityTable,collectorCycle.inletTemperature);
% collectorCycle.quality = 0;
% collectorCycle.volume = pi*(receiver.radius)^2*receiver.length*3; % 3 is an arbitrary factor here.
% collectorCycle.material = collectorCycle.fluid.material;
%Field
field.columnFlowRate = field.totalFlowRate/field.parallel;
field.nTroughs = field.parallel*field.series;