Peewee
Members-
Posts
75 -
Joined
-
Last visited
Content Type
Profiles
Forums
Developer Articles
KSP2 Release Notes
Everything posted by Peewee
-
the cyclers [difficulty: inane]
Peewee replied to tuskiomi's topic in KSP1 Challenges & Mission ideas
Did you read the challenge guidelines? It does matter. -
No idea, those inputs produced this result for me:
- 4,948 replies
-
- ksptot
- mission planning
- (and 3 more)
-
Gravity transfer frustration.
Peewee replied to Hour Hero Yes's topic in KSP1 Gameplay Questions and Tutorials
That's not a simple task. You might want to check out this tool to help with the math, but if you insist on doing it all yourself you can change the conics patch mode to see your flyby relative to the particular body, and increase CONIC_PATCH_LIMIT (in settings.cfg, located in the install directory) to see more than 3 SoI's ahead. -
Fastest Drop Pod from Orbit to Landing
Peewee replied to Zack's topic in KSP1 Challenges & Mission ideas
6. Taking advantage of aerodynamic bugs is frowned upon. (No magical canard turbines) :/ -
Fastest Drop Pod from Orbit to Landing
Peewee replied to Zack's topic in KSP1 Challenges & Mission ideas
Wow, that was an impressive time. I had a much simpler, smaller design, but only managed 1:40 (Fired rocket at 42:47, impacted at 44:27). VIDEO MIRROR Disclaimer: I had Kerbal Alarm Clock (not a performance-enhancer, just to keep track of the time in-game) and Kethane installed, though the ship itself was all stock parts. I also used the debug menu to make getting into orbit trivial. Bonus: Land at high speed and survive (40 m/s) Actually thrust downwards to increase speed before slowing down. (Ok technically I didn't thrust straight down because I swung it around the wrong way by accident, but I did the spirit of this one) Practical size (You could have multiple of them docked to a space station) Technically an IVA view for the final 20 seconds of landing. Edit: I just saw the part of the OP about the .craft file. It's really quite simple and I can't be bothered to upload it, so here's how it's built and how to land it: Start with the pod seen in the video (has impact tolerance of 50 m/s). Add 4 backwards-facing sepratrons on the wide side of the pod. Add a decoupler. Add a SRB (Might experiment with the big one, but the smaller one is fine for LKO insertions). Correct the staging because it's terrible. SRB fires first, then the decoupler, then the sepratrons. Flight instructions: 1. If you need to go down RIGHT NOW, aim more down than retrograde (poorly demonstrated in the video), otherwise just aim retrograde to deorbit normally. 2. Fire the SRB at the lowest point of your orbit. 3. The craft will face the correct direction on its own, that's why you put the sepratrons in the back. 4. Watch the RADAR altimeter in IVA view: fire when it's between 200m and 300m. You have ~0.7 seconds to fire the landing motors or else you will hit the ground too fast., so pay attention. -
Mechanical Mouse Industries - Kethane & Payload Packs Released!!!
Peewee replied to Dani-Sang's topic in KSP1 Mod Releases
Or you know, just get the free one at http://www.7-zip.org/ -
Yes, that's what I'm working towards. The math has to be done before any simple 'run it and it just works' scripts can be made, and it just so happens that rendezvous scripts take a significant amount of annoyingly hard to debug math, which hasn't already been given to us by MuMechLib. In the meantime, have a simple script I whipped up in an hour: http://pastebin.com/ZZ0VGU6N It will take you on a quick spin around the Kerbin neighborhood and land. (Kerbin -> Mun -> Minmus -> Kerbin)
-
It's fine if you're just checking out the code, but if you want to execute anything in-game, you'll need to get rid of the .txt on the end. Once again, it's a work in progress, and doesn't actually do anything useful yet. As it is now, Rendezvous() will just spam some debugging text to the console then throw an error about trying to do math on a nil value (AN is not currently returned because it was inaccurate). I'll edit that post before it causes any more confusion.
-
I'm using code from MuMechLib, so I'm obligated to release those parts under GPL. To keep everything tidy, I'm releasing it all under GPL. Here's my script as-is. (still obviously a work in progress) ------NON-FUNCTIONAL CODE------ http://pastebin.com/uxCZJgjT http://pastebin.com/X8qgZGdE ------FOR SCRIPT WRITERS ONLY------ ------DON'T BOTHER DOWNLOADING IF YOU JUST WANT IT TO WORK------
-
You need to run it in a coroutine. See kerbin2mun.lua in the OP for an example. After thorough testing, I've determined that my FindAN() function doesn't work as expected. If anyone has a working algorithm to get the true anomaly of the ascending node between two orbital planes, I'd be much obliged. What I've got so far (significant portions ported over from MuMechLib): -- TAKES: orbital position vector (3d vector) -- RETURNS: geocentric latitude and longitude? (2d vector) at given orbital element vector function LatLongofVector(vinput) -- get the geocentric latitude and longitude of a orbital element vector local rads = math.pi/180 local c1 = vinput[1] local c2 = vinput[2] local c3 = vinput[3] local lat = math.atan(c3 / math.sqrt(c1*c1 + c2*c2))/rads local long = math.atan2(c2, c1)/rads if (c1 < 0) then long = long + 90 elseif (c1 > 0) then long = long + 270 end local coord = {lat, long} return coord; end -- TAKES: geocentric coordinates (latitude, longitude) -- RETURNS: true anomaly (radians) when orbit is over coordinates -- note: May or may not actually work right now... function GetTrueAnomalyAtGeoCoordinates(orbitParams, coords) local temp2 = math.deg(math.atan(math.tan(math.rad(coords[2]))/math.cos(math.rad(orbitParams.I)))) -- print("temp2: " .. temp2) local truAnomaly = 180 + (temp2 - orbitParams.AoP) if (truAnomaly > 360) then truAnomaly = truAnomaly - 360 end return math.rad(truAnomaly) end -- TAKES: target orbital parameters -- RETURNS: (radians) true anomaly of ascending node -- note: does not work yet. function FindAN(orbitParams, targetParams) print("finding AN") local vA = math.sin(math.rad(orbitParams.I))*math.cos(math.rad(orbitParams.LAN)) local vB = math.sin(math.rad(orbitParams.I))*math.sin(math.rad(orbitParams.LAN)) local vC = math.cos(math.rad(orbitParams.I)) local tA = math.sin(math.rad(targetParams.I))*math.cos(math.rad(targetParams.LAN)) local tB = math.sin(math.rad(targetParams.I))*math.sin(math.rad(targetParams.LAN)) local tC = math.cos(math.rad(targetParams.I)) -- vector3D.cross(v, t) inline here local c = {} c[1] = vB*tC - vC*tB c[2] = vC*tA - vA*tC c[3] = vA*tB - vB*tA -- print("end vector stuff C") local coordsA = LatLongofVector(c) coordsA[2] = coordsA[2] - orbitParams.LAN --don't ask me. if (coordsA[2] < 0) then coordsA[2] = coordsA[2] + 360 end print("AN coords?: ".. coordsA[1], coordsA[2]) -- Got latitude/longitude of node A -- local latB = coordsA[1] * (-1) -- local longB = coordsA[2] + 180 -- if (longB > 360) then -- longB = longB - 360 -- end -- local coordsB = {latB, longB} -- Got latitude/longitude of node B -- print("end coordinate stuff C") local nodeA = GetTrueAnomalyAtGeoCoordinates(orbitParams, coordsA) -- local nodeB = GetTrueAnomalyAtGeoCoordinates(orbitParams, coordsB) -- print("end node stuff A") -- TODO: figure out a way to distinguish ascending and descending nodes. -- if (GetRadiusAtTruAnomaly(orbitParams, nodeA) > GetRadiusAtTruAnomaly(orbitParams, nodeB)) then return nodeA -- else -- return nodeB -- end end I also have true anomaly -> eccentric anomaly -> mean anomaly conversions.
-
Alright, 319 lines in (including whitespace and comments) and I >think< I have a ship that matches planes with its target. More testing/debugging is required though. I found some interesting time equations at http://braeunig.us/space/ , and I think this script could be (on paper anyway) capable of making a combined transfer/minor plane change burn to intercept with the target, then simply kill relative velocity to synchronize orbits, but that's not very likely in the first version.
-
As far as I can tell, you have to do the math yourself. From OrbitExtensions.cs: /// <summary> /// Finds the coordinates of a state vector. /// </summary> /// <returns> /// Double[] {lattitude, longitude} /// </returns> /// <param name='vinput'> /// State vector /// </param> public static double[] LatLonofVector(Vector3d vinput) { //get the geocentric latitude and longitude of a orbital element vector double rad = Math.PI/180; double c1 = vinput.x; double c2 = vinput.y; double c3 = vinput.z; double lon = 0; double lat = Math.Atan(c3/Math.Pow((c1*c1) + (c2*c2), .5))/rad; if (c1 < 0) { lon = (Math.Atan(c2/c1)/rad) + 90; } else { lon = (Math.Atan(c2/c1)/rad) + 270; } var coord = new[] {lat, lon}; return coord; } /// <summary> /// Orbit foo, this finds the nodes of two orbits /// </summary> /// <returns> /// The true anomaly of the ascending node(descing node is 180degrees off) /// </returns> /// <param name='orbit'> /// Orbit. /// </param> /// <param name='tgtorbit'> /// Target Orbit /// </param> public static double FindAN(Orbit orbit, Orbit tgtorbit) { double rad = Math.PI/180; double Lan1 = orbit.LAN; double inc1 = orbit.inclination; double Lan2 = tgtorbit.LAN; double inc2 = tgtorbit.inclination; //see braeunig.us/space... cross product of two orbital planes gives the node location var a = new Vector3d(Math.Sin(inc1*rad)*Math.Cos(Lan1*rad), Math.Sin(inc1*rad)*Math.Sin(Lan1*rad), Math.Cos(inc1*rad)); var b = new Vector3d(Math.Sin(inc2*rad)*Math.Cos(Lan2*rad), Math.Sin(inc2*rad)*Math.Sin(Lan2*rad), Math.Cos(inc2*rad)); var c = new Vector3d(0, 0, 0); c = Vector3d.Cross(a, ; var coord = new double[] {0, 0}; coord = LatLonofVector(c); //get the coordinates lat/lon of the ascending node double lat = coord[0]; double lon = coord[1]; //go look at the diagrams at braeunig.us/space double α = lon - Lan1; //its all greek to me if (α < 0) α += 360; double λ = Math.Atan(Math.Tan(α*rad)/Math.Cos(inc1*rad))/rad; double x = 180 + (λ - orbit.argumentOfPeriapsis); if (x > 360) return 360 - x; else return x; } My current (completely untested) lua port: -- takes (vector{x,y,z}) (?), returns coordinates{lat, lon} function LatLonofVector(vinput) -- get the geocentric latitude and longitude of a orbital element vector rads = math.pi/180 local c1 = vinput[1] local c2 = vinput[2] local c3 = vinput[3] local lon = 0 local lat = math.atan(c3/math.sqrt((c1*c1) + (c2*c2)))/rads; if (c1 < 0) then lon = (math.atan(c2/c1)/rads) + 90; else lon = (math.atan(c2/c1)/rads) + 270; end local coord = {lat, lon} return coord; end --takes (vessel, mechjeb.core.targetVessel), returns true anomaly of ascending node function FindAN(subj, tgt) rads = math.pi/180 local Lan1 = subj.orbitLAN local inc1 = subj.orbitInclination local Lan2 = tgt.orbit.LAN local inc2 = tgt.orbit.inclination -- see braeunig.us/space... cross product of two orbital planes gives the node location local a = {math.sin(inc1*rads)*math.cos(Lan1*rads), math.sin(inc1*rads)*math.sin(Lan1*rads), math.cos(inc1*rads)} local b = {math.sin(inc2*rads)*math.cos(Lan2*rads), math.sin(inc2*rads)*math.sin(Lan2*rads), math.cos(inc2*rads)} local c = {0, 0, 0} c = VectorCross(a, --easy enough to define yourself local coord = {0,0,0} coord = LatLonofVector(c) --get the coordinates lat/lon of the ascending node local lat = coord[1] local lon = coord[2] -- go look at the diagrams at braeunig.us/space local d = lon - Lan1; -- its all greek to me if (d < 0) then d = d + 360 end local e = math.atan(math.tan(d*rads)/math.cos(inc1*rads))/rads local x = 180 + (e - subj.orbitArgumentOfPeriapsis) if (x > 360) then return 360 - x else return x end end Yesterday, I decided to split off most of the math into a different script for calculating true/mean/eccentric anomalies, from a table of orbital parameters. That should make it easier to keep up to date; should just need to update the way the getParameters(ship) function works when KSP/MechJebLib updates and everything breaks.
-
Hm, I don't understand how mechjeb's Autom8 lua thing actually works. Is there a way to use "FindAn(orbit, tgttorbit)" (in OrbitExtensions.cs when looking through the source) in a lua script, or would I have to do the math myself? Derp, figured out previous problem. Sorry for anyone trying to follow my problems, but make sure you have a target selected before trying to use 'mechjeb.core.targetVessel'. Also, the varying interfaces for mechjeb.core.target* and vessel.* are driving me nuts. example: mechjeb.core.targetVessel.orbit.inclination vs vessel.orbitInclination Also, put a space between while and ( due to LuaSharp being buggy.
-
Are all the functions required to automatically rendezvous with another craft available? Off the top of my head, you'd need a way to do the following: - [launch or get into] a (preferably) lower orbit, preferably in the same plane, but if not... - Align planes (matching both LAN and inclination) - Align lines of apsides (make apoapsis and periapsis line up correctly) - Catch up (get the craft close enough, preferably < 1 km) - Transfer to target's orbit (aka match velocity aka insertion burn) I imagine the hard parts would be aligning planes and lining up the apsides (since I haven't noticed any mechjeb functions that do those automatically yet), but I don't know if those functions actually exist yet.
-
Same here.
-
Fixed your link.
-
Here\'s what the map looks like, adjusted for highest known peak = white.
-
Picture of your satellite, Turnip199? Oh by the way I made a perl script to find the highest recorded peak, and it\'s 3284.9m at 52.32 N 70.05 E. So try to avoid flying below 3300m.