# RichterSnipes

## *pew pew pew*

#### Visitor Messages

Showing Visitor Messages 61 to 75 of 91
1. December 2nd, 2012 4:08 PM
Jambo51
In theoretical terms, at least, 100% sure. With a delay of 1 and a length of 0, it should produce a note length of 1.

In practical terms, I don't know.
2. December 2nd, 2012 1:36 AM
Jambo51
My plan was to have note length just be a decimal value between 1-192, and on compilation, the tool would calculate if a frame delay change was necessary, and if it was, insert the command, followed by the note. I was going to try to hide this complexity from the end users, if at all possible.

From my immediate rationalisation, I worked out that the max values of frame delay and note length would be 0xC and 0xF respectively. These 2 values combined give the maximum note length of 192 in GBC note architecture. This also means every note value in this range is covered.

In terms of other commands, they would take the obvious necessary parameters, it would be up to the too to rationalise them so that they make sense when played back on the GBC.
3. November 29th, 2012 2:04 PM
Jambo51
OK, implemented those changes and I'm getting sensible sounding noises out. If I could just understand and parse the actual noise behaviour (ie, how it chooses what sound it makes), I'd be done.

Oh well, in any case, I'm about to move on to assembly into the Gen 1 and 2 ROMs.
Got any preferred formats for that? I was thinking something that looked a bit like XSE in terms of the music commands (since the music is technically a script, when you think about it).

So an example music command would be:
Note C 4 12 7 1
Where the parameters stand for:
C = Note to play
4 = Octave
12 = Length
7 = Velocity

The reason for so many parameters is that asking a user to understand the Frame Delay command is asking a bit much, IMO, so if I have it in each note command and parse it correctly, I can add it in on the fly when necessary.

Also, incidentally, brilliant Profile Image! :D
4. November 25th, 2012 10:24 PM
Jambo51
I can tell you that E3 determines the noise pattern on Gen 2, although I'm unsure as to how it actually defines anything, as it points to a bunch of numbers which carry no obvious meaning. As for the rest, I'll see about implementing the changes at least, so that the notes exported make sense.
5. November 25th, 2012 1:32 AM
Jambo51
Well, that pretty much covers the full gauntlet of questions for Gen 1, as (distortion and noise notwithstanding) I seem to have very accurate reproductions of the music coming out now. There are some issues with the rising notes, but I'll look into them more accurately at a later date.
6. November 24th, 2012 8:34 AM
Jambo51
Fair enough, I worked off that assumption, and it seems to be working. Now another question, do you know where the headers for the songs in this region (22330-23F51) are? They're missing from any known list, and they would appear to include the battle themes (given that those are absent from what my tool can export currently).

I have tried to find them, with no luck, so I'm a bit bemused.
7. November 24th, 2012 7:21 AM
Jambo51
Don't suppose you know the "max" value of it? I assume it can't be 0, for obvious reasons, so does it just operate from D1 - DF?
8. November 24th, 2012 7:01 AM
Jambo51
Frame delay defines how long each "tick" of the music actually takes. It's normally set to 0xC, but can be changed to lengthen/shorten a note's duration. With a note length of 0 and a frame delay of 0xC, the note lasts 12 (0xC) frames on a GBC, or W06 on GBA (due to the halving effect).

In GSC, there's a command which directly modifies this frame delay to allow for longer/shorter notes, and I was wondering if there was an analogous command on RBY, since some notes don't play at the correct rate on export with my tool, and I assume that with the systems being so similar, there will be a command which modifies this value somewhere.
9. November 24th, 2012 2:59 AM
Jambo51
I don't suppose you know what the "Frame Delay" command is on Gen 1? It's command 0xD8 on GSC and has a format of D8 [Frame Delay] [Note Volume].

The other question has to be what does command E8 in RB and presumably Y do? It doesn't appear to actually take any parameters, so it's somewhat confusing. It's just there...
10. November 23rd, 2012 3:57 PM
Jambo51
Ah, it turns out the off notes are caused by incorrect note alignment in the definitions.ini.
11. November 23rd, 2012 3:51 PM
Jambo51
VG = VoiceGroup

It's already heavily reliant on an ini which comes with it to define what each command does, in terms of the Pokémon music engine.

The thing is, even if the Pokemon engine is unusual, most other engines out there have to have the same end effect in terms of what commands do, so it should be entirely possible to modify the code to suit other games.

In other related news, I rewrote the code to support the RB style (direct references) as well as the GSC song table approach. Using this, I was able to get a recognisable Pallet Town out of the ROM, though it's pitched too low (Probably something to do with the different note structure, given that the code's written around note C being in one specific place, which it no longer is). Other than that, it runs reasonably well!
12. November 23rd, 2012 1:38 PM
Jambo51
OK, a bit of a development on the Gen 1 music front. It turns out they (Red and Blue, at least) don't use music tables (as in a list of pointers to song headers), and in fact they have collections of song headers grouped together in at least 2, if not 3, sets of locations in the ROM. (Quite how these songs are referenced in game, I don't know, but I digress).

I say 3 as some songs are missing from these headers AND there is a 3rd set of the triangle waves, the other sets of which follow directly on from the headers in question.

Now, the problem is, detecting which style any given games uses will be awkward, and it will be even more awkward if the game uses a different style altogether.

This is, quite frankly, a disheartening discovery (for obvious reasons). I can probably get around it by "creating" a song table in my tool's memory which it could use to navigate the songs, however. This could be complex, especially since I'll have to make it work for an unknown (at compile time) number of "table fragments". I would also need to take into consideration the lack of any obvious boundaries to the table fragments.

However, shy of writing a brand new tool for them, I can't see what else I can do.

Other than this, I have added code to my tool which generates a VG for the ROM you have open, and "rips" the relevant triangle waves along with it. In this way, I can ensure that (if the triangle wave location is known, then they can be ported to gen 3 easily).
13. November 22nd, 2012 11:02 AM
Jambo51
Yeah, I would appreciate knowing how you used those commands to do the pitch bending, since it looks very much like I am going to need them for some of the songs in GSC and RBY.

Other than that, and the ever annoying Noise tracks, the songs are sounding very, very accurate now.
14. November 21st, 2012 3:04 PM
Jambo51
Well, 96 / 0 would be undefined, so I made it act like z = 1 under that circumstance IF ANF ONLY IF there is still modulation to be run. (Hence my reference to XX and Y not being 0 as well).

I haven't yet investigated this distortion command beyond looking at the basic structure. It doesn't help that I'm unsure of the effect that the command will have, which can't be said of any other command I have investigated so far (except from the "Tone" command, I still don't know what that does).

Based purely on what I can hear from the evolution jingle, it appears that distortion is somewhat analogous to pitch bending on Gen 3, but don't quote me on that.
15. November 21st, 2012 6:37 AM
Jambo51
An addition to that, what I have discovered is that if z = 0 (with respect to that modulation document you sent me earlier), AND xx != 0 AND y != 0, then LFOS = 96, otherwise, LFOS = 0.

It turns out that this was why the modulation in the rocket hideout was incorrect, as the LFOS wasn't correctly set because I hadn't implemented this rule.

Now, this weird distortion you reference, I already know of one song in GSC which would appear to use it (the Evolution jingle) and the command for this distortion (in GSC at least) is E0.

E0 XX YY (NL) - Unsure if NL is part of the command. (Where N = Note, L = Length as defined elsewhere)

distortion x, y(,nl) (in that format you previously mentioned)

However, I currently have no understanding of how this works, beyond the fact that it takes 2 (obvious) parameters, though something I remember seeing once indicated that it actually took 3 parameters, which may mean that the distortion command also includes the note which has to be distorted as well.

Location
USA
Gender
Male ♂
Nature
Modest
Go Team
Do not display
• Signature
My hack:

#### Statistics

Total Posts
Activity by Forum
Visitor Messages
Blog
General Information
• Join Date: October 24th, 2011
• Referrals: 1

#### Friends

Showing Friends 1 to 6 of 6
•  Jambo51 Glory To Arstotzka
•  Sefuree Lord Kek

All times are GMT -8. The time now is 2:07 PM.