Difference between revisions of "SummerOfCodeProposal 2011 LuaAI JodyNorthup"
|  (→Include as much technical detail about your implementation as you can) | |||
| Line 149: | Line 149: | ||
| ====Include as much technical detail about your implementation as you can==== | ====Include as much technical detail about your implementation as you can==== | ||
| − | + | As in [[SummerOfCodeProposal_JodyNorthup|my prior application]], I have moved this to [[#Project Details|Project Details]] for organization and ease of reading. | |
| − | |||
| − | |||
| ====What do you expect to gain from this project?==== | ====What do you expect to gain from this project?==== | ||
Revision as of 04:23, 13 April 2011
| This page is related to Summer of Code 2011 | 
| See the list of Summer of Code 2011 Ideas | 
| This is a Summer of Code 2011 student page | 
| Project: SoC_Ideas_LuaAI_2011 | 
Contents
- 1 Description
- 2 IRC
- 3 SoC Application
- 4 Questionnaire
- 4.1 Basics
- 4.1.1 Write a small introduction to yourself.
- 4.1.2 State your preferred email address.
- 4.1.3 If you have chosen a nick for IRC and Wesnoth forums, what is it?
- 4.1.4 Why do you want to participate in summer of code?
- 4.1.5 What are you studying, subject, level and school?
- 4.1.6 What country are you from, at what time are you most likely to be able to join IRC?
- 4.1.7 Do you have other commitments for the summer period ? Do you plan to take any vacations ? If yes, when.
 
- 4.2 Experience
- 4.2.1 What programs/software have you worked on before?
- 4.2.2 Have you developed software in a team environment before? (As opposed to hacking on something on your own)
- 4.2.3 Have you participated to the Google Summer of Code before? As a mentor or a student? In what project? Were you successful? If not, why?
- 4.2.4 Are you already involved with any open source development projects? If yes, please describe the project and the scope of your involvement.
- 4.2.5 Gaming experience - Are you a gamer?
- 4.2.6 What type of gamer are you?
- 4.2.7 What type of games?
- 4.2.8 What type of opponents do you prefer?
- 4.2.9 Are you more interested in story or gameplay?
- 4.2.10 Have you played Wesnoth? If so, tell us roughly for how long and whether you lean towards single player or multiplayer.
- 4.2.11 If you have contributed any patches to Wesnoth, please list them below. You can also list patches that have been submitted but not committed yet and patches that have not been specifically written for GSoC. If you have gained commit access to our SVN (during the evaluation period or earlier) please state so.
 
- 4.3 3) Communication skills
- 4.3.1 Though most of our developers are not native English speakers, English is the project's working language. Describe your fluency level in written English.
- 4.3.2 What spoken languages are you fluent in?
- 4.3.3 Are you good at interacting with other players? Our developer community is friendly, but the player community can be a bit rough.
- 4.3.4 Do you give constructive advice?
- 4.3.5 Do you receive advice well?
- 4.3.6 Are you good at sorting useful criticisms from useless ones?
- 4.3.7 How autonomous are you when developing ? Would you rather discuss intensively changes and not start coding until you know what you want to do or would you rather code a proof of concept to "see how it turn out", taking the risk of having it thrown away if it doesn't match what the project want
 
- 4.4 Project
- 4.4.1 Did you select a project from our list? If that is the case, what project did you select? What do you want to especially concentrate on?
- 4.4.2 Why did you choose this project?
- 4.4.3 Include an estimated timeline for your work on the project. Don't forget to mention special things like "I booked holidays between A and B" and "I got an exam at ABC and won't be doing much then".
- 4.4.4 Include as much technical detail about your implementation as you can
- 4.4.5 What do you expect to gain from this project?
- 4.4.6 What would make you stay in the Wesnoth community after the conclusion of SOC?
 
- 4.5 Practical considerations
- 4.5.1 Are you familiar with any of the following tools or languages?
- 4.5.2 Which tools do you normally use for development? Why do you use them?
- 4.5.3 What programming languages are you fluent in?
- 4.5.4 Would you mind talking with your mentor on telephone / internet phone? We would like to have a backup way for communications for the case that somehow emails and IRC do fail. If you are willing to do so, please do list a phone number (including international code) so that we are able to contact you. You should probably *only* add this number in the application for you submit to google since the info in the wiki is available in public. We will *not* make any use of your number unless some case of "there is no way to contact you" does arise!
 
 
- 4.1 Basics
- 5 Project Details
Description
Jody Northup - Improve and extend Lua AI scripting facilities
This is the Lua AI improvement idea.
If I am accepted for this project, I will bring the Lua AI scripting functionality up to par with the current C++ AI programming functionality by first exposing all of the C++ AI support functions to Wesnoth's Lua API, and then adding WML utilities to include and handle custom Lua AI code in WML modules.
I expect the first step to involve an in-depth analysis of the C++ AI functions and an inventory of the gaps in the currently-implemented Lua AI API, followed by tedious Lua API programming to expose each of those functions. I expect that the second step will involve communication with the development community to determine good WML specifications for the use of Lua AI code in UMC modules.
IRC
Upthorn, Upth
SoC Application
Questionnaire
(Largely copied from my successful application last year)
Basics
Write a small introduction to yourself.
My name is Jody Northup. I am a 26 year old college student from the United States. Under normal circumstances, I should have graduated by now, but there have been a number of obstacles on my route to academic success.
I have been programming since I was introduced to C++ in the summer of 1999.
State your preferred email address.
upthorn@gmail.com
If you have chosen a nick for IRC and Wesnoth forums, what is it?
- irc: Upthorn
- irc alternate: Upth
- Wesnoth forums: Upthorn
- gna.org: Upthorn
Why do you want to participate in summer of code?
It is a good opportunity to gain experience in aspects of programming that aren't covered in classes, it is a great way to contribute to the open source community on projects that I believe in or even make use of myself, being able to contribute usefully to something gives me a great sense of accomplishment, and it is much more fun than any other summer job opportunity I know of.
What are you studying, subject, level and school?
I'm an undergrad with an undeclared major at Sacramento City College. In terms of credit earned, I am in my fourth year, in terms of time spent I am in my 6th year, and in terms of the length of time remaining until I graduate, I might as well be halfway through my 2nd year. In another year I hope to transfer to the University of Maryland, where I plan to double-major in Computer Science and Linguistics, getting a simultaneous degree in both if possible.
What country are you from, at what time are you most likely to be able to join IRC?
I live on the west coast of the United States (UTC-7 during the summer), but my sleep schedule is fairy flexible. I am generally available on IRC between around 18:00 and 9:00 UTC, but I can change this during the coding period if it is inconvenient to my mentor. Until my class period ends, I will have limited availability on Mondays.
Do you have other commitments for the summer period ? Do you plan to take any vacations ? If yes, when.
I have a recurring social engagement all day every Wednesday, but this commitment can be cancelled if there is urgent work to be done. I also have D&D from 18:00 to 0:00 on Friday nights (1:00 to 7:00 Saturdays, UTC). Additionally, I would like to take up an additional part-time job during the summer if I can fit one into the schedule, but there are no definite plans around this at the moment.
Experience
What programs/software have you worked on before?
- A variety of programming projects for high school and college classes
- I have hacked around quite a bit on open source emulators. Primarily the rerecording branch of gens (see TASVideos.org introduction and these forum threads for more information, with some work also being done on snes9x and mupen64. Relevantly, my work on gens has included some additions/improvements to its Lua API.
- I have done a great deal of feature programming and debugging work on the Sonic 1 MegaMix romhacking project for the sega genesis.
- I have done some simple reverse engineering work to examine a simple archive file format and help create a translation patch for the Japanese indie game Bunny Must Die.
- I have done some minor testing and debugging work on a project to encapsulate windows games in a deterministic environment, allowing input to be recorded and replayed without concern for RNG input from the system clock, or other sources.
- I worked on ScummVM for Summer of Code 2009, implementing an API to allow engine modules to negotiate with backend modules to determine color depth.
- I implemented Wesnoth's persistent data WML extension for Summer of Code last year.
Have you developed software in a team environment before? (As opposed to hacking on something on your own)
Yes, I frequently collaborate with other developers in my development of gens, and Sonic 1 Megamix, as well as having worked in pair and group projects for classes. And, of course, I contributed to ScummVM for 2009's Summer of Code, as well as Battle for Wesnoth during 2010's.
Have you participated to the Google Summer of Code before? As a mentor or a student? In what project? Were you successful? If not, why?
I participated in 2009's summer of code as a student for ScummVM. My project was providing support for RGB color games (Note: dead link pending assistance from melange team to update). I was successful, but had a great snag towards the end as I completed my project as proposed before the midterm, went on a pre-arranged 2-week vacation, and had a great deal of difficulty with the project I was assigned to work on for the remainder of the summer of code period. I participated in 2010's summer of code as a student with Battle for Wesnoth. My project was to extend WML to support persistent data for UMC developers. I was assigned Crab as a mentor, and had a very positive experience, in which I learned a lot about WML parsing, and where the errors lie in my approach to software development. My project took the entire length of the coding period, and was completed successfully with his guidance.
Are you already involved with any open source development projects? If yes, please describe the project and the scope of your involvement.
I have been the project maintainer and coordinator of the Gens-rerecording project since about mid-2006, having produced many new features, created a google code project page, and organized the development of many more during that time.
Gaming experience - Are you a gamer?
Yes, I enjoy games, although lately I haven't been playing them as much as I used to.
What type of gamer are you?
I am an obsessive perfectionist when it comes to gaming. I always try again and again until I get the best possible outcome, and I've collected all the items. Sometimes the frustration from this will drive me to save-scum, or edit my saves outright.
What type of games?
I love all types of games, from real time strategy (command & conquer, starcraft, total annihilation) and turn-based strategy (wesnoth, civilization) to RPGs (Planescape: Torment, Skies of Arcadia), adventures (King's Quest, Space Quest, The Void/Тургор), platformers (Sonic the Hedgehog, Mario) and racing games (Virtua Racing, Burnout) and even to First person shooters (Deus Ex, Unreal Tournament) and simulations (Escape Velocity, Dwarf Fortress)
What type of opponents do you prefer?
I prefer opponents that are on the same level or slightly better than me (so, generally, ones that are not very good).
Are you more interested in story or gameplay?
I cannot choose between story and gameplay. In the best games, there is no separation between the two, but either can hold up a good game on its own.
Have you played Wesnoth? If so, tell us roughly for how long and whether you lean towards single player or multiplayer.
Yes, I got hooked on wesnoth during my vacation in 2009, and the Heir to the Throne campaign became one of the greatest difficulties I had in accomplishing additional work for ScummVM. I am not very good at strategy games, so I have not even attempted multiplayer yet (except to the extent of debugging Persistence WML in multiplayer contexts.)
If you have contributed any patches to Wesnoth, please list them below. You can also list patches that have been submitted but not committed yet and patches that have not been specifically written for GSoC. If you have gained commit access to our SVN (during the evaluation period or earlier) please state so.
- I did submit a patch to correct the VC9 project files, but then I realized it was a duplicate of one from three weeks earlier.
- Patch 1612 -- implements Sapient's proposed changes to allied healing.
- Patch 1619 -- provides prototype implementation of Crab's proposed WML syntax for saving/loading persistence data.
- I gained commit access to the BfW SVN during (or slightly before) the coding period for last year's Summer of Code. It appears that I still retain this access.
3) Communication skills
Though most of our developers are not native English speakers, English is the project's working language. Describe your fluency level in written English.
I am a native English speaker, and my proficiency with written English is better than average.
What spoken languages are you fluent in?
I am a fluent native speaker of English, can communicate alright in Japanese, and am at a basic level in Mandarin and Korean. I was unfortunately unable to learn Russian this year, due to scheduling conflicts.
Are you good at interacting with other players? Our developer community is friendly, but the player community can be a bit rough.
I do not know about wesnoth players specifically, but I am fairly good at interacting with players of other games. I tend to be friendly and open, and I understand that the other players' insults and other such things are just for fun and don't mean anything.
Do you give constructive advice?
I do give constructive advice whenever I can, although sometimes I think I cause offense by mistake. I always try to think my criticism through so that there is a clear indication of how the aspect could be improved.
Do you receive advice well?
I believe so, as long as it is clear and helpful.
Are you good at sorting useful criticisms from useless ones?
I think I am pretty good at sorting helpful criticism from bikeshed painting, yes.
How autonomous are you when developing ? Would you rather discuss intensively changes and not start coding until you know what you want to do or would you rather code a proof of concept to "see how it turn out", taking the risk of having it thrown away if it doesn't match what the project want
I like to keep a good balance between discussing changes and coding proof of concepts. In 2009's summer of code, I had to interact extensively with the development community in order to design a useful API for them, but at times when it wasn't clear what the community preference was, I would make a proof of concept to demonstrate the features and drawbacks of a given method. Some of the work would be thrown out, but I did my best to maximize the amount of work that could be reused on a different method. During last year's summer of code, the project specifications were almost entirly a collaboration between myself and my mentor, which allowed me to take a much more independent approach in designing my solution, therefore involving much less refactoring and wasted effort.
Project
Did you select a project from our list? If that is the case, what project did you select? What do you want to especially concentrate on?
Yes: I selected [Lua AI improvement] project from your ideas list. I would like to focus on ensuring that UMC authors can easily include custom Lua AI code in their modules.
Why did you choose this project?
- AI is an interest of mine that has always felt unapproachable, and this seems like it would provide a good opportunity to learn how AI works in a game.
- Customizability seems like one of Wesnoth's strongest "selling point"s, and if scripted AI routines are second-class citizens, difficult to use and unable to replicate hard-coded functionality, it is a major hole in Wesnoth's support for customization. In other words: it seems like a very useful goal, and I would like to improve wesnoth in a meaningful way.
- I wanted to challenge myself more this year than I have on previous years. Working on or around AI scares me a little bit, and I want to find out if my fears are founded or not.
- I have worked on extending an application's Lua interface before, and am confident that I can accomplish that in a timely manner.
Include an estimated timeline for your work on the project. Don't forget to mention special things like "I booked holidays between A and B" and "I got an exam at ABC and won't be doing much then".
Pessimistic:
- Now - May 23: Research the C++ AI functionality and the Lua AI functionality. Assess gaps.
- Milestone: By May 24th, know which C++ functions are not yet exposed.
 
- May 23 - July 15: Expose C++ AI functions to Lua
- Milestone: By July 15th (Midterm), Lua AI has access to all C++ AI functionality.
 
- July 15 - August 15: Design and implement proof-of-concept WML extensions for "Lua AI standard library"
- August 15 - August 26: Refine WML extensions through iterative debugging
- Milestone: By August 26th (Final deadline) Lua AI can be scripted by UMC devs with full functionality of C++ AI, and Lua AIs can be easily included in WML modules.
 
Optimistic:
- Now - May 23: Research the C++ AI functionality and the Lua AI functionality. Assess gaps. Begin correcting.
- May 23 - June 13: Finish exposing C++ AI functions to Lua
- Milestone: By June 13th, Lua AI has access to all C++ AI functionality.
 
- June 13 - July 15: In cooperation with UMC development community, analyse Lua AI scripting problem space and design solutions to reduce or eliminate difficulties affecting the development of custom Lua AIs.
- Milestone: By July 15th (midterm), have preliminary specifications for a standard library of utility functions and WML extensions for Lua AI scripting.
 
- July 15 - August 15: In cooperation with UMC development community, refine and implement Lua AI function library and WML extension specifications.
- Milestone: By August 15th, UMC developers are, on average, content with the Lua AI scripting facilities provided to them.
 
- August 15 - August 26: Assess and correct gaps in documentation.
- Milestone: By August 26th, project is completed and thoroughly documented.
 
Include as much technical detail about your implementation as you can
As in my prior application, I have moved this to Project Details for organization and ease of reading.
What do you expect to gain from this project?
A better understanding of AI concepts, experience working with game AI, a better understanding of my capacities as a programmer, a sense of having been able to do something useful for someone besides myself, and a nifty t-shirt from google.
What would make you stay in the Wesnoth community after the conclusion of SOC?
My interest in the project itself, and any relationships I might forge with community members during the coding period, and the free time to make a meaningful commitment to wesnoth development.
Practical considerations
Are you familiar with any of the following tools or languages?
* Subversion (used for all commits)
Yes, I have used it extensively for gens development, megamix development, my work on ScummVM in 2009, and my work on Wesnoth last summer.
* C++ (language used for all the normal source code)
Yes, I have been working with C++ for nearly 11 years now.
* STL, Boost, Sdl (C++ libraries used by Wesnoth)
I am fairly familiar with the STL, and worked almost exclusively with SDL on ScummVM in 2009. I am new to Boost, but in the past I have been able to catch on to these things fairly quickly with a little bit of practice.
* Python (optional, mainly used for tools)
I have worked with python somewhat, contributing a few minor bugfixes to the Civilization 4 mod "Fall From Heaven II"
* build environments (eg cmake/autotools/scons)
I do not have any experience with cmake, autotools, or scons.
* WML (the wesnoth specific scenario language)
I have some minor experience with WML, from editing my own wesnoth savegames last summer.
* Lua (used in combination with WML to create scenarios)
I have experience both in scripting Lua, and in working with the Lua C API to provide hooks and bindings.
Which tools do you normally use for development? Why do you use them?
- C/C++: I generally use Microsoft Visual C/C++, because I am familiar with it from classes, and because it provides a very useful debugger that allows me to trace problems to their source quite quickly. I have used Dev-C++ in the past, though.
- Java: Eclipse, because it was recommended to me and I do not know anything about the others, and also because it provides a very useful debugger facility.
- Lua: I just use Crimson editor, because it has support for Lua syntax highlighting, and Lua is interpreted, not compiled.
What programming languages are you fluent in?
C, C++, Lua, Java, Javascript.
Would you mind talking with your mentor on telephone / internet phone? We would like to have a backup way for communications for the case that somehow emails and IRC do fail. If you are willing to do so, please do list a phone number (including international code) so that we are able to contact you. You should probably *only* add this number in the application for you submit to google since the info in the wiki is available in public. We will *not* make any use of your number unless some case of "there is no way to contact you" does arise!
I have provided my phone number in the application at google.
Project Details
Overview
I will improve and extend wesnoth's support for custom Lua AI scripts in two major steps
Step one involves use of the Lua API to create several Lua interface functions to invoke C++ functions from, and seems fairly straightforward.
Step two involves the extension of WML and the Lua API in order to better facilitate creation and customization of AIs, and is significantly more complex.
For step two, I propose a couple of extensions and modifications to WML
[Lua] and [AI] tag enhancement
I propose to add a "source" element to [Lua] and [AI] tags as an alternative to the "code" element. The source element will specify the relative path to a Lua file which contains the desired Lua code.
Files loaded from the "source" element in these tags will be indexed globally so that multiple WML modules can reference the same Lua script file without causing the file to be loaded into memory multiple times.
[group] tag
I propose to create a "[group]" tag for scenario authors to specify AI scripts per-group of units. This would be accompanied by a "[groups]" subtag in unitWML, which contains a unit's group memberships in priority order. Additionally a group could be associated with a standard unit filter in order to automatically apply itself to all new units created which match the filter.
Additionally, the Lua API will be extended to allow Lua scripts to send messages to unit groups, so that groups can be dynamically created and commanded during the execution of a scenario. This will be accomplished by significant additions to the WML parsing engine to teach it about the new unit group concept, creation of an as-yet indeterminate number of Lua or Lua API functions yet to be named, and possibly a group-related extension to Standard Unit Filters.
Proposed syntax for the [group] tag is provided below, in the proposed WML extension section.
Deliverables
Mandatory
- Full exposure to Lua of C++ AI support functions. -- Due by July 15th
- C++ AI support functions exposed to Lua interface -- Due by July 5th
- Wiki documentation of all additions to Lua interface -- Due by July 12th
 
- Lua loadable non-redundantly into WML from external files -- Due by August 5th
- Basic functionality of "source" element in [Lua] tags and [AI] tags with engine="Lua" -- Due by July 25th
- WML properly parses "source" element and passes file contents to Lua engine -- Due by July 22nd
- Source element syntax and usage is thoroughly documented on -- Due by July 25th
 
- Lua file-loading deduplication functionality -- Due by August 5th
- Script manager to store path of scripts on first load, compare new requests to files already loaded, and return reference to the loaded file -- Due by August 5th
 
 
- Basic functionality of "source" element in [Lua] tags and [AI] tags with engine="Lua" -- Due by July 25th
- [group] tag -- Due by August 26th
- Elaboration under progress
 
Optional
To be determined via discussion with mentors and UMC development community.
Proposed WML extension
In progress