Table of Contents

<html>

&nbsp;&nbsp;&nbsp;Beppo&nbsp;… is not entirely insane.

</html>

Beppo: Buffalo PHP Pattern Maker

Buffalo PHP is a group that meets once a month in Buffalo Hackerspace.

Synace was looking for a project to talk about on an ongoing basis. I suggested Beppo.

The rest is not yet history–but it may be history in the making.

If you do not see a larger version of this thumbnail to the right of the flying buffalo, then you do not have a browser that shows SVG images.

Goals

The goal of this project is to provide a pattern-drawing application that will:

Methods

Data tables

Layout and MySQL queries.

Front end

How a user will construct a schedule

Opening Move
Middle Steps

Repeat Middle Steps until 17 maneuvers have been chosen.

Pretty pictures

How to implement it

New routine

.pdf output

from SVG to .pdf

Back end

Showing the next set of available options

First draft

Graphics routines

First draft: graphics library

<html> <table class=“inline” width=“70%” border=“1” cellpadding=“4”>

<tr>
  <td colspan="3" align="center">Top Margin</td>
</tr>
<tr>
  <td colspan="3" align="center">Heading: Name, author, date. </td>
</tr>
<tr>
  <td colspan="3" align="center">Takeoff boilerplate + wind arrow. </td>
</tr>
<tr>
  <td>&nbsp;</td>
  <td>1. Center</td>
  <td rowspan="2">2. Turnaround</td>
</tr>
<tr>
  <td rowspan="2">4. Turnaround</td>
  <td>3. Center</td>
</tr>
<tr>
  <td>5. Center</td>
  <td rowspan="2">6. Turnaround</td>
</tr>
<tr>
  <td rowspan="2">8. Turnaround</td>
  <td>7. Center</td>
</tr>
<tr>
  <td>9. Center</td>
  <td rowspan="2">10. Turnaround</td>
</tr>
<tr>
  <td rowspan="2">12. Turnaround</td>
  <td>11. Center</td>
</tr>
<tr>
  <td>13. Center</td>
  <td rowspan="2">14. Turnaround</td>
</tr>
<tr>
  <td rowspan="2">16. Turnaround</td>
  <td>15. Center</td>
</tr>
<tr>
  <td colspan="2">17. Center</td>
</tr>
<tr>
  <td colspan="3" align="center">Landing boilerplate.</td>
</tr>

</table>

</html>


Maneuvers only

Maneuvers with maneuver description

Manipulating the maneuver drawings

Second draft: drawing tool?

Image library

CSS

Constraints

Beppo must:

Blurb

Those who fly precision radio-controlled aerobatics at the highest level (FAI F3A) are given one night to jointly select, then individually master 17 maneuvers to be flown the next day.

Competitors would like to have a program that can allow them to draw up unknown schedules both for practicing unfamiliar routines as well as for making up the real unknowns at contests.

There are approximately 300 variations of center maneuvers and about 200 turnaround variants.

Although not every center maneuver can be hooked up to every turnaround, the number of permutations and combinations is still quite large.

The final output of the program should be a .pdf file that shows the 17 selected maneuvers (9 center maneuvers [5 upwind, 4 downwind] and 8 turnaround maneuvers) in mirror images–one version will show the maneuvers with the wind coming from the left and other will show them with the wind coming from the right.

Beppo might not fly, Orville, but it should be an instructive experience to try to get it off the ground.

Rules for composing an unknown schedule

The composition of the unknown manoeuvre schedules shall be done by the finalists with each finalist nominating, in turn, an appropriate centre or turn-around manoeuvre from the approved and published list of manoeuvres. This nomination and selection of manoeuvres may be either manual or computer-aided. The order of selection will be determined following the random flight draw with the order repeating until the manoeuvre schedule is complete. The nominated and selected manoeuvres must conform to the following general criteria:

1. The entry of one manoeuvre must be matched to the exit of the previous manoeuvre, for entry altitude, entry attitude (level upright or level inverted flight), size of manoeuvres (wide as in a horizontal eight or narrow as in a stall turn) and direction of flight.

2. No duplication of manoeuvres.

3. No duplication of centre manoeuvres from the same manoeuvre group but excluding group 23 manoeuvres.

4. Spins are entered into the wind.

5. All horizontal rolling manoeuvres (4 pt. rolls, 8 pt. rolls, slow rolls, etc) are usually flown in a downwind direction.

6. Snap rolls may be flown positive or negative, unless specified.

7. Not more than five manoeuvres of each schedule may be K = 5.

8. Only 17 manoeuvres per unknown schedule.

a) Take-off sequence into wind (not judged and not scored).

b) 9 centre manoeuvres (5 upwind, 4 downwind).

c) 8 turn-around manoeuvres (4 left and 4 right).

d) Landing sequence into wind (not judged and not scored).

9. There is no limit on the total K-factor, and the maximum score.

5G.3. Once an unknown schedule has been composed and checked for correctness it must receive the final approval of the Jury and the contest director. Printed copies, showing the Aresti pictograms and manoeuvre lists, shall then be distributed to team managers, finalists, judges, jury members, and non-finalists who are scheduled to perform warm-up flights. A sufficient number shall be made available by the organisers for spectators.

5G.4. The judges shall receive instructions after the composition of the unknown schedule covering the unknown manoeuvres to ensure that they are fully aware of the sequence of manoeuvres.

5G.5. Aresti drawings of the unknown schedules must be provided to finalists and judges.

5G.6. Finalists may not attempt practice flights of an unknown schedule between its composition and the finals flights either with a model aircraft or via electronic flight simulator. Evidence of such practice shall be deemed cheating and shall lead to disqualification from the championships. Hand-held stick models are permitted.

5G.7. In addition to the warm-up flight for the finals known schedule, at least two warm-up flights must be arranged for the unknown schedule. The unknown warm-up flights may be observed by the finalists and must be judged. Under no circumstances should the flight scores of any warm-up flights be tabulated.

Suggestions from a competitor

Quique Somenzini, the person whom Ryan Smith mentions in this e-mail, won the FAI F3A world championship in 2007. Ryan knows what he is talking about.

From: "Ryan Smith"
Date: Sat, 23 May 2009 22:50:10 -0400

Marty,

This sort of combines your e-mail directly to me, and the e-mail that you
posted to the list, about what I was thinking for the program. I don't know
which method would be easier, but here is what I was thinking.

The purpose that I would be using this program, and I'm sure Andrew and
Jason and Brett, and any other host of FAI guys that would like to make
their own unknowns to practice with would be to start off with a base
drawing of each maneuver stored in a data bank and then have the maneuver
modifiers (rolls, etc.) in a bank as well. This way there wouldn't be a lot
of pictorial data stored in the program, just basic maneuver groups and
their individual modifiers.

One would input the unique identifier for the maneuver from the FAI sporting
code, and it would have information attached to it to know which maneuver
family to pull the base drawing from, and also what modifiers need to be
attached to it. It would draw the Aresti only when these were input, so I
would assume that the program would be less data intensive, and be able to
run quicker on older computers or what not.

For example, let's take a reverse Cuban eight, top entry, with 2/4 point
rolls. The identifier for this maneuver in the FAI Sporting Code is 10.11.
So the user would input 10.11 in a box, and it would take this, and with the
data attached to it, would take a base Cuban eight drawing, add the 2/4
point rolls to the 45* lines, and "invert" the maneuver because it's
starting at the top. It would only have the basic Cuban eight drawing stored
on the system and the 2/4 point roll modifier would be added when necessary.

Other niceties to consider would be to ensure that you can't input a wrong
maneuver in the sequence, as in, you can't have a maneuver with an inverted
entry following a maneuver with an upright exit, maybe an error code could
flash and a substitute maneuver could be suggested that has the correct
orientation. Also, if one could input a set of rules that defined where the
beginning of the maneuver drawing and where the end of the maneuver drawing
was so that there could be automated connector lines drawn, that would be
helpful. The only other problem would be how to organize the drawings on one
page since they don't exactly fit to a grid in some of the more obscure
sequences.

I know this is a lot of information, and I'm doing a poor job explaining it.
It's times like these that I wish I had pursued computer programming in
school so that I could make a program like this. I think the way I have
setup to organize it would be ideal because the people designing a given
sequence are not going to be without the sporting code, so there is nothing
exotic in the least to input, just the simple, unique identifier to the
maneuver.

Food for thought. I will see what I can come up with. I will be returning to
school to finish my degree in Finance soon, so I may pick up a few computer
classes to satisfy my curiosity. Thanks for being a good vent, I hope some
of this made sense to you. Let me know what you think of it.

Regards,
Ryan

-----Original Message-----
From: Martin X. Moleski, SJ [mailto:moleski@canisius.edu] 

Ryan Smith wrote:

> Thank you for your offer, Marty. I have an idea how I would like something
> like that to be setup, but I have no computer programming experience. I may
> see what I can come up with. I'll probably continue to have a need for a
> program like this, because I always seem to need to write unknowns.

The first step is to get digital pictures of the maneuvers.

I guess we'll need two of each--one for each wind direction.

Once we have the graphics, manipulating them is not all that hard.

> In 2007 when I was creating unknowns for Quique, I would pick the maneuvers
> out, and then draw them with a pen and paper to scan and send to him. This
> precluded me from easily making two call sheets for both wind directions.

This is what computers were designed for.

They are great tools for drudge work.

				Marty

Center Maneuvers

1. Loop

2. Two loops

3. Avalanche

4. Triangular loop

5. Square loop

6. Square loop on corner

7. Six-sided loop

8. Cobra roll

9. Golf ball

10. Cuban eight

11. 45 degree down

12. Figure Z

13. Hourglass

14. Vertical eight

15. Square horizontal eight

16. Figure M

• Centre half-loop is always flown negative (inverted)

17. Top hat

18. Humpty bump

19. Spin

20. Stall turn

21. Double Immelmann

22. Rolling circle

23. Roll

Turnaround manoeuvres

A. Half square loop

B. Half loop

C. Split S

D. Immelman turn

E. Figure 9

F. Half cuban eight

G. Spin

H. Stall turn

J. Top hat

K. 45 degree up

L. Humpty bump

M. Humpty bump from top

Frequently Asked Questions (FAQs)

Why don't you ...

Credits