|
|||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object | +--org.gjt.universe.accrete.AccreteObject | +--org.gjt.universe.accrete.Protoplanet
Implements a body which can accrete dust and gas.
This Java class is copyright 1998 by Carl Burke. All rights reserved. Substantial sections of this code were previously distributed in different form as part of 'starform' (copyright 1989 Matthew Burdick)
This software is provided absolutely free and without warranty, including but not limited to the implied warranties of merchantability and fitness for a purpose. You may use this code for any legal purpose provided that you do not charge for it; this implies that you may use this code as a component of a commercial system as long as the additional functionality of the commercial system is greater than what this code provides and that the commercial system is not primarily intended as a simulation of solar system formation. In other words, if you want to write a science-fiction computer game that uses the code in this package to build objects which are used in the game, that's great and permitted; if you use this code to make a kickass solar-system-builder, you are not allowed to distribute that software except for free.
You are allowed and encouraged to modify this software, provided that this copyright notice remains intact. This notice may be reformatted, but not removed.
If you do use this software, I and the contributing authors listed
under "Acknowledgements" would appreciate some recognition. If you make
changes, I would appreciate it if you would pass those changes back to me
for possible inclusion in the master. At the time this notice was prepared,
my email address is cburke@mitre.org and the home page for this software is
http://www.geocities.com/Area51/6902/w_accr.html.
Matt Burdick, the author of 'starform' (freeware copyright 1989); much of the code (particularly planetary environments) was adapted from this.
Andrew Folkins, the author of 'accretion' (public domain) for the Amiga; I used chunks of his code when creating my displays.
Ed Taychert of Irony Games, for the algorithm he uses to classify terrestrial planets in his tabular CGI implementation of 'starform'.
Paul Schlyter, who provided information about computing planetary positions.
Field Summary | |
double |
a
|
double |
crit_mass
|
double |
dust_density
|
double |
e
|
boolean |
gas_giant
|
double |
mass
|
Protoplanet |
next_planet
|
static double |
PROTOPLANET_MASS
|
double |
reduced_mass
|
Fields inherited from class org.gjt.universe.accrete.AccreteObject |
cr |
Constructor Summary | |
Protoplanet(double in,
double out)
Constructs a new seed protoplanet at a random location within the specified range. |
|
Protoplanet(Protoplanet p)
Copy constructor |
Method Summary | |
boolean |
accretes_gas()
Determines if the protoplanet is massy enough to accrete gas. |
double |
inner_effect_limit(double cloud_eccentricity)
Calculates innermost limit of gravitational influence. |
double |
inner_reduced_limit(double cloud_eccentricity)
Calculates innermost limit of gravitational influence. |
double |
mass_density(boolean dust,
boolean gas)
Calculates unit density of material to be accreted from the specified dust band. |
boolean |
massOK()
Verifies that the protoplanet mass is non-zero and also different from the injected seed size. |
double |
outer_effect_limit(double cloud_eccentricity)
Calculates outermost limit of gravitational influence. |
double |
outer_reduced_limit(double cloud_eccentricity)
Calculates outermost limit of gravitational influence. |
void |
print()
Not currently implemented; really should be toString() anyway. |
void |
reduce_mass()
Performs the mass 'reduction' calculation for the inner accretion loop. |
Methods inherited from class org.gjt.universe.accrete.AccreteObject |
about, LognormalDeviate, nextDouble, NormalDeviate, random_eccentricity, random_number |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
public static double PROTOPLANET_MASS
public double a
public double e
public double mass
public double reduced_mass
public double crit_mass
public double dust_density
public boolean gas_giant
public Protoplanet next_planet
Constructor Detail |
public Protoplanet(double in, double out)
in
- Minimum semi-major axis of orbitout
- Maximum semi-major axis of orbitpublic Protoplanet(Protoplanet p)
Method Detail |
public double inner_effect_limit(double cloud_eccentricity)
cloud_eccentricity
- Eccentricity of the dust disc (0.0 to 1.0)public double outer_effect_limit(double cloud_eccentricity)
cloud_eccentricity
- Eccentricity of the dust disc (0.0 to 1.0)public double inner_reduced_limit(double cloud_eccentricity)
cloud_eccentricity
- Eccentricity of the dust disc (0.0 to 1.0)public double outer_reduced_limit(double cloud_eccentricity)
cloud_eccentricity
- Eccentricity of the dust disc (0.0 to 1.0)public void print()
public boolean massOK()
public boolean accretes_gas()
public void reduce_mass()
public double mass_density(boolean dust, boolean gas)
|
|||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |