/* * $Id: trans.h,v 1.1.1.1 2005/09/18 22:04:57 dhmunro Exp $ * Routines for transporting a ray through a cylindrical mesh. */ /* Copyright (c) 2005, The Regents of the University of California. * All rights reserved. * This file is part of yorick (http://yorick.sourceforge.net). * Read the accompanying LICENSE file for details. */ #ifndef TRANS_H #define TRANS_H #include "track.h" /* ---------------------------------------------------------------------- */ /* Solve the transport equation assuming that both the opacity and * source function are constant within each zone. Return the overall * absorption and self-emission along the ray. */ extern void FlatSource(double *opac, double *source, /* opacity, emissivity */ long kxlm, long ngroup, /* opac, source dimens */ RayPath *path, /* ray path through mesh */ double *absorb, double *selfem, /* attenuation factor and * self-emission for * entire path */ double *work); /* scratch space -- 3*(path->ncuts-1) */ /* Solve the transport equation assuming that the source function * varies linearly with optical depth across a zone. The opacity is * assumed to be constant within each zone. (Hence, opac must be zone * centered, while source is point centered.) Return the overall * absorption and self-emission along the ray. */ extern void LinearSource(double *opac, double *source, /* opacity, emissivity */ long kxlm, long ngroup, /* opac, source dimens */ RayPath *path, /* ray path through mesh */ double *absorb, double *selfem, /* attenuation factor and * self-emission for * entire path */ double *work); /* scratch space -- 3*(path->ncuts-1)+1 */ /* Reduce x[i+1]= a[i]*x[i]+b[i] for i=0,...,n-1 to * x[n]= a[0]*x[0]+b[0] -i.e.- return a[0], b[0] * May use an algorithm which clobbers a[1:n-1], b[1:n-1] as well. */ extern void Reduce(double *a, double *b, long n); /* The LinearSource transport solver requires a point centered source * function; the given source function is zone centered. * This point centering scheme is local to the four zones surrounding * the point, with weights which are large for zones whose optical * depth (along either k or l) is near 1. * The algorithm requires 4*(kmax*(lmax+1)+1) doubles as working space. * * An unrelated Milne condition is applied for points which lie on * the vacuum boundary of the problem. */ extern void PtCenterSource(double *opac, double *source, long kxlm, long ngroup, Mesh *mesh, Boundary *boundary, double *work); /* ---------------------------------------------------------------------- */ #endif