# THE AWESOME GUITAR GAME # Project Report Embedded System Design CSEE 4840 Spring 2012 Semester Academic supervisor: Professor Stephen Edwards Imré Frotier de la Messelière (imf2108) Front page picture source: imf2108. # Acknowledgements I wish to thank Professor Stephen Edwards for all his help throughout this project and for making this work an instructive and enjoyable experience. # Contents | Introduction | | | | | |--------------|------|-------------------------------------------------------------------------|----|--| | 1 | Ove | rview of the project and its objectives | 9 | | | | 1.1 | Revised version of the Project proposal | 9 | | | | | 1.1.1 Project Introduction | 9 | | | | | 1.1.2 Project Design | 9 | | | | | 1.1.3 Milestones | 9 | | | | 1.2 | Objectives of the project | 9 | | | 2 | Pro | ect Design Document | 11 | | | | 2.1 | Abstract | 11 | | | | 2.2 | Project Design Introduction | 11 | | | | 2.3 | Hardware Implementation | 11 | | | | 2.3 | 2.3.1 Altera DE2 FPGA | 11 | | | | | 2.3.2 Game Guitar and input controller | 12 | | | | | 2.3.3 Audio format and memory dimensioning | 12 | | | | | 2.3.4 Video controller | 13 | | | | 2.4 | Software Implementation | 13 | | | | 2.4 | 2.4.1 The NIOS program: game loop and event handling | 13 | | | | | | 15 | | | | | 8 | 15 | | | | 2.5 | 2.4.3 Representation of the notes | | | | | 2.5 | Milestones | 16 | | | 3 | | estones of the Project | 17 | | | | 3.1 | Milestone 1: March 27th | 17 | | | | 3.2 | Milestone 2: April 10th | 17 | | | | 3.3 | Milestone 3: April 24th | 17 | | | | 3.4 | Final run, part one: May 23rd | 17 | | | | 3.5 | Final run, part two: September 30th | 17 | | | 4 | Disc | ussion of the architectural and timing design | 18 | | | | 4.1 | Architectural design | 18 | | | | | 4.1.1 MATLAB code | 18 | | | | | 4.1.2 PYTHON code | 18 | | | | | 4.1.3 NIOS II C code | 18 | | | | | 4.1.4 QUARTUS VHDL code | 21 | | | | 4.2 | Timing design | 31 | | | | | 4.2.1 Extraction of the beats | 31 | | | | 4.3 | Correct timing of the beats | 31 | | | | | 4.3.1 Use of interruptions to indicate that the guitar has been pressed | 32 | | | | 4.4 | Additional tracks of study | 32 | | | | | 4.4.1 Alternative beats handling system | 32 | | | | | 4.4.2 Storage of the song | 33 | | | | | 4.4.3 Playing the song | 33 | | | | | 4.4.4 Video display using sprites | 33 | | | 5 | Hardware 34 | | | | | | | |-----|--------------------------------------------|---------------------------------------|----|--|--|--|--| | | 5.1 | FPGA | 34 | | | | | | | 5.2 | Game Guitar | 34 | | | | | | | 5.3 | VGA display | 36 | | | | | | 6 | Experiences and issues in implementation 3 | | | | | | | | | 6.1 | Playing the song | 37 | | | | | | | 6.2 | Storage using the SDRAM | 37 | | | | | | | 6.3 | Bugs solving | 37 | | | | | | | 6.4 | Merging several parts of the project | 37 | | | | | | 7 | Summary including lessons learned | | | | | | | | | 7.1 | Summary of the project | 39 | | | | | | | 7.2 | Lessons learned | 39 | | | | | | | 7.3 | Some advice for future projects | 40 | | | | | | 8 | List | ing of all source code | 41 | | | | | | | 8.1 | MATLAB source code | 41 | | | | | | | 8.2 | PYTHON source code | 42 | | | | | | | 8.3 | C source code | 42 | | | | | | | 8.4 | VHDL source code | 42 | | | | | | Co | nclus | sion | 45 | | | | | | Ril | hling | raphy | 46 | | | | | | | 9 | · · · · · · · · · · · · · · · · · · · | •• | | | | | | Ar | inexe | | 48 | | | | | | | MA | ΓLAB source code | 48 | | | | | | | | beatavg.m | 48 | | | | | | | | beat.m | 48 | | | | | | | | calclistftrs.m | 50 | | | | | | | | chromagram_E.m | 50 | | | | | | | | chromagram_IF.m | 51 | | | | | | | | chromagram_P.m | 51 | | | | | | | | chrombeatftrs.m | 51 | | | | | | | | chromnorm.m | 52 | | | | | | | | chrompwr.m | 52 | | | | | | | | chromrot.m | 52 | | | | | | | | chromxcorr.m | 52 | | | | | | | | coverDistMxLists.m | 53 | | | | | | | | coverTestLists.m | 53 | | | | | | | | distmatrixwrite.m | 53 | | | | | | | | fexist.m | 53 | | | | | | | | fft2chromamx.m | 54 | | | | | | | | fft2melmx.m | 54 | | | | | | | | history-bragg-autoco.m | 54 | | | | | | | | history-golddust-xcorr.m | 54 | | | | | | | | hz2octs.m | 54 | | | | | | | | ifgram.m | 54 | | | | | | | | ifptrack.m | 54 | | | | | | | | listfileread.m | 54 | | | | | | listfilewri | ite.m | | |----------------------|---------------------------------------|------| | localmax. | .m | 55 | | mkblips.n | m | 55 | | mp3read.i | m | | | mymkdir. | .m | 59 | | octs2hz.m | n | 60 | | tempo.m | | 60 | | testlist.m | | 61 | | test.m . | | 63 | | <b>PYTHON</b> source | ce code | | | toHexArr | ray.py | | | encode.py | y | 63 | | randomiz | e.py | 64 | | shortest_t | time_dist.py | 64 | | C source code | | 65 | | Hello Wo | orld.c | 65 | | | code | | | AWESON | ME_GUITAR.qpf | 67 | | AWESON | ME_GUITAR.qws | 67 | | | ME_GUITAR_TOP.dpf | | | AWESON | ME_GUITAR_TOP.jdi | 68 | | AWESON | ME_GUITAR_TOP.qsf | 68 | | | ME_GUITAR_TOP.sof | | | | hd | | | | | | | | | | | | _debug_module.vhd | | | | _ c_<br>_debug_module_wrapper.vhd | | | | am_default_contents.mif | | | | am.mif | | | | bench.vhd | | | | eCounter.vhd | | | | er.vhd | | | | av_config.v | | | | controller.v | | | | n_controller.vhd | | | | n_controller_hw.tcl | | | | 8731_audio.vhd | | | | p.vhd | | | | troller.vhd | | | | itroller_hw.tcl | | | | atroller_inst.vhd | | | | itroller2_inst.vhd | | | | atroller3_inst.vhd | | | | itroller4_inst.vhd | | | | atroller5_inst.vhd | | | | ntroller6_inst.vhd | | | jtag_uart. | | | | 5 C- | rem.bsf | | | | em.ptf | | | 11105_5 y Su | • • • • • • • • • • • • • • • • • • • | . 00 | | nios_system.qip | 86 | |------------------------------------|----| | nios_system.sopc | 87 | | nios_system_generation_script | 87 | | nios_system_log.txt | 87 | | nios_system.ptf.pre_generation_ptf | 88 | | nios_system_setup_quartus.tcl | 88 | | pulser.vhd | 88 | | sopc_builder_log.txt | 89 | | sram.vhd | 89 | | timer.vhd | 90 | | timer.vhdl | 93 | | timer_hw.tcl | 94 | | timer inst.vhd | 94 | #### Introduction This report gives an account of my work during the Embedded System Design class of the Spring 2012 semester. It focuses on the description of my class project: the Awesome Guitar Game, aka TAGG. I have worked on this project all semester long, beginning with the Project Proposal and the Project Design documents, then learning the necessary skills to realize it throughout the laboratory assignments of the class, and finishing by implementing the project itself. The Awesome Guitar Game is based on the same principle as in the famous "Guitar Hero" video game series[32]. TAGG is an interactive game where the user can play a game guitar to match up the notes as displayed on the screen. The display continuously reflects that the note has been or has not been correctly played. Most of the technical aspects of this project have been realized based on Professor Stephen Edwards' class documentation and tutorials[23]. In section 1 of the report, I shall present an overview of the project and its objectives. Then, in section 2, I will give more information about the project design document. Section 3 will be dedicated to the milestones of the project and section 4 to a discussion of the architectural and timing design. Section 5 focuses on the hardware used in this project. Then section 6 will be related to the experiences and issues in implementation, while section 7 will be a summary of the project, including the lessons that I learned. Finally, section 8 contains a listing of all source code. # 1 Overview of the project and its objectives In this section, I shall present an overview of my project, including a revised version of my project proposal. # 1.1 Revised version of the Project proposal # 1.1.1 Project Introduction In this project, I implement an interactive game where the user can play a game guitar to match up the notes as displayed on the screen. The game principle is the same as in the famous "Guitar Hero" video game series[32]. #### 1.1.2 Project Design I implement the project using an Altera DE2 board, a game guitar, a VGA display and a pair of speakers. Altera DE2 Development and Education board and Game Guitar (altera.com/education/univ/images/boards/de2.jpg; i14.ebayimg.com/01/i/001/22/73/0b2412.JPG) When the user starts the game, the screen displays a stream of notes. If the user presses the correct button at the correct instant, his score is increased. To make the user even more involved, the display will reflect that the note has been correctly played. The implementation is done on VHDL and C. I have five buttons on the game guitar which are connected to the GPIOs of the FPGA. #### 1.1.3 Milestones Please refer to section 3: Milestones of the Project. #### 1.2 Objectives of the project The global objectives of the project are: - building the hardware for the Game Guitar, - developing the VHDL and C software, • having the game running. More precisely, these objectives can be described as follows: - Build the hardware for the Game Guitar - Detect the input of the game guitar - Extract the beats of a song - Ask for the correct key presses, based on the beats - Analyze the correctness of the key presses of the player - Keep track of the score # 2 Project Design Document In this section, I present the detailed project design documents, which are a revised version of the project design document submitted earlier during the year. #### 2.1 Abstract This document describes my preliminary project design implementation based on my research at the time when this document was due. In this project, I implement an interactive game where the user can play a game guitar to match up the notes as displayed on a screen. The expected music will be played in the background and the score will grow higher whenever the user presses the correct key. For this project, I will use an Altera DE2 board, a NIOS II processor, a game guitar, a VGA display and a pair of speakers. #### 2.2 Project Design Introduction This game is inspired by the Guitar Hero video game series [32]. I use a Guitar Hero controller for PlayStation 2 to serve as the "game guitar", it has 5 colored buttons as well as a button to simulate the action on the guitar string. When the user starts the game, he will hear the music. The screen will display a stream of notes. If the user presses the correct button at the correct instant, his score is increased. To make the user even more involved, the display will reflect that the note has been correctly played. The implementation of this project will be done on an Altera DE2 board. I will use a NIOS II software processor as the central element of my design, and will write programs in C for this processor. The processor will interact with modules implemented in VHDL. #### 2.3 Hardware Implementation #### 2.3.1 Altera DE2 FPGA The Altera DE2 FPGA will be used to include a NIOS II processor, that will interact with several controllers. Altera DE2 Development and Education board (altera.com/education/univ/images/boards/de2.jpg) It is the central point of my design as it: - gets the user input through the game guitar, - contains all the information needed for the game. The NIOS interacts through an Avalon Bus with the controllers. #### 2.3.2 Game Guitar and input controller Game Guitar (i14.ebayimg.com/01/i/001/22/73/0b2412.JPG) As said before, I use a Guitar Hero controller for PlayStation 2 as my game guitar. The game guitar is used to get the user input in an enjoyable way for the player. When this document was first released, I didn't know at that point how the guitar would be connected to the FPGA board. So I would open it and figure that out during the first milestone. The controller will take the input from the the 5 buttons and when the string button is pressed it updates a memory location assigned to it with the color button pressed and sends an interruption to the processor. The interruption is caught and the click is processed. The processor then clears the memory location and the interruption. I will filter for the button bouncing effect at the controller level, not at software level. The connection from the guitar to the board will be one of following solutions: - 1. Using a custom cable that maps every button on a single wire using GPIOs - Reusing whatever I could find in the guitar: USB, RS 232 or whatever I will find inside the guitar #### 2.3.3 Audio format and memory dimensioning WARNING: This part did not make it to the final version of the project. However, it has involved a consequent amount of work. This is why I wish to keep mentioning it here. The song is stored in the SDRAM in Binary format. It is sampled down from a sampling rate of 44.1Khz to 8 Khz in order to reduce the memory requirements for each song. I tested that the song still sounds good at a sampling rate of 8Khz. Every sample is represented on a 8 bits scale. The total memory requirements of a 3 minutes song are 1.44 MB(3\*60\*1\*8000 bytes). This order of magnitude suggests that we use the SDRAM (I need more than the SRAM and less than the SDCARD.). I will therefore be able to store a few songs. I will use the SRAM to store the sprites and the beats. I will have at maximum 5 sprites of 32x32x8 bit (monochromatic sprites): 5kbytes. The size of the beats binary stream is not fixed as of now. More details are given at the end of this document in the section "Representation of the notes". #### 2.3.4 Video controller WARNING: This part did not make it to the final version of the project. However, it has involved a consequent amount of work. This is why I wish to keep mentioning it here. The video controller is in charge of displaying the sprites on the screen. It is controlled by the processor with the following commands: - Add a sprite with as parameter the color and the id - Clear the sprite list The video controller has a dedicated SRAM for the sprite. I will take as a model the video controller in the Nintendo NES. I aim at a sprite stack of size 4 (4 sprites in the same line maximum). I will have 4 custom sprites for the project: for the note, the note pressed, the note rightly pressed and the background. I will have sprites for the text and numbers in the same fashion than LAB2. #### 2.4 Software Implementation #### 2.4.1 The NIOS program: game loop and event handling The program that runs on the NIOS processor will be in charge of the Main Game loop, which is a concept that is generally used in video games. It will rely on a timer either as an Avalon Peripheral or a component of the NIOS processor if available to ensure a constant frame rate. Meanwhile, the program could be interrupted to deal with key presses. Every time a key is pressed, a visual feedback is given for the few next frames and the new score is immediately computed. WARNING: The following part did not make it to the final version of the project. However, it has involved a consequent amount of work. This is why I wish to keep mentioning it here. The graphical interface will look like the following: Every iteration of the main loop, I will update the display by computing the new positions of the falling notes. #### 2.4.2 Beat tracking The instants at which the notes appear on the screen are not random events. They are synchronized with the beats in the song so as to give a more natural effect. The beats of the song are extracted by a Beat Tracking Algorithm I implemented in Matlab. [35] These beat instances are saved as a .txt file for further usage. They are extracted once and for all so that we do not need to use Matlab when running my game. #### 2.4.3 Representation of the notes WARNING: This part did not make it to the final version of the project. However, it has involved a consequent amount of work. This is why I wish to keep mentioning it here. After having run the beat tracking algorithm on Matlab we obtain a text file that contains n notes $n_i$ , with i in [0; n-1]. Each note is characterized by a color and a timestamp when it is played. To transfer the beats in the FPGA, we will convert this text file into a binary format. I built it inspired by domain specific binary format such as ILDA for laser shows [31]. The binary "stream" associated with a song is made of a header (metadata) and the notes. The header contains: - the id of the song on 1 byte, - the number of notes in the song on 2 bytes. 2 bytes seem reasonable based on the number of beats we detect per song in matlab (roughly 400 so 256 = 1 byte is too low). Following the header we have the notes. Each note is characterized by: - its "color" on 1 byte. I take more than 3 bits (which is the minimal bound to represent the 5 colors of my guitar's buttons) since I might add new information later. I also go for it to remain consistent with the rest: every field is made of one or more bytes - its timestamp on m bytes I haven't yet determined m but to do it I will do some experiments. I will start by finding u integer such as $t/2^u < t_{min} < t/2^u - 1$ with $t_{min}$ the minimum space in seconds between two following beats in the note list and t a constant which represents the maximum length of a song we permit in seconds. I will then choose m such as the multiple of 8 (a byte) $8^*m$ that comes after u. If it happens not to be precise enough in practice, I will increase the value of m. To compute the binary stream from the output of the Matlab algorithm: - I set the song id and write it in one byte. - I discretise all the timestamps to the closer multiple of $t/2^3m$ and store these values. - Once it is done, I know the number of notes; I write it in the binary stream in two bytes. - I write the notes one by one in the binary stream following the right format. # 2.5 Milestones Please see section 3: Milestones of the Project. # 3 Milestones of the Project In this section, I provide the details of the three milestones of the project. #### 3.1 Milestone 1: March 27th - I will buy and construct the game guitar. - I shall detect key inputs with the game guitar. - I will play a song (raw sound format) from a SD card in the FPGA. - I will develop a program to build a script of a given song. This means, to produce a file that contains the notes and their corresponding positions for this particular song. - I shall finally make a prototype of the base game engine in Java. ### 3.2 Milestone 2: April 10th - I will work on the sprites and study how to do graphics and how to encode the sound efficiently (how many bits, how much information I can store...). - The Java game prototype will integrate the work on scripts from the first milestone. - I shall have designed the game internal functioning to ensure a constant frame rate (on paper). - I will have started implementing the game. # 3.3 Milestone 3: April 24th - I shall finalize the game. - I will develop an algorithm to compute the score. - I shall improve the performance of the game and work on the graphics. #### 3.4 Final run, part one: May 23rd - I finished coding the VHDL files. - I finished coding the C files. ### 3.5 Final run, part two: September 30th - I finished writing the project report. - I finished creating the project presentation. # 4 Discussion of the architectural and timing design In this section, I present the final version of the Awesome Guitar Game. ## 4.1 Architectural design #### 4.1.1 MATLAB code This code extracts the beats out of a song. It comes from LabRosa. It is run and stored beforehand in the project. More precisely, given a mp3 song, the MATLAB code extracts the beats of the song and stores them in a text file. This text file is then being processed by a PYTHON code that converts it to a format recognizable in C. Here is an excerpt of the README for LabROSA-coversongID. "See http://labrosa.ee.columbia.edu/projects/coversongs/ for more info." "Key functions: - t = tempo(d,sr); estimates the tempo in BPM of audio waveform d at sample rate sr - b = beat(d,sr); estimates the beat times (in sec) of audio waveform d at sample rate sr - qlist = calclistftrs(querylistfilename); calculates beat-synchronous chroma feature matrices for all the way or mp3 files listed, one per line, in the named file, returning a list of calculated feature files, then... - R = coverTestLists(qlist); compares each feature file named in the qlist against every item and returns R as a square matrix of distance between each pair." #### 4.1.2 PYTHON code This code stores into a new format the songs that have been preprocessed through MATLAB so that they may be readable inside the VHDL project: - toHexArray.py - encode.py - randomize.py - shortest\_time\_dist.py #### 4.1.3 NIOS II C code The main code of the NIOS II[12][11] C program is the following: • hello\_world.c It enables to control the beats and to keep track of the score of the user. The related console serves as a visual display for the game where the player can see which note he is supposed to play and what his current score is. I set the displayed key each time val is incremented. ``` static void irqhandler (void * context, alt_u32 id) val ++; key = 1; IOWR_SDIRECT(INPUTCONTROLLER_INST_BASE, 0, 0); // reset request ``` #### This is where I store the beats I extracted earlier with MATLAB: ``` int beats[] = {0x00b4,0x00c8,0x00f0,0x0116,0x0141,0x016a,0x0193,0x01bb,...,0x4b71,0x4b98,0x4bc0,0x4be6,0x4c0d,0x4c33,0x4c5d,0x4c82,0x4cad,0x4cd7}; ``` #### This is the interruption detection function: ``` static void input_isr ( void* context, alt_u32 id) { valz++; IOWR_16DIRECT(INPUTCONTROLLER_INST_BASE, 0,0); return; } ``` #### The following is part of the main(): ``` int main(){ ``` # This is how I register the interruptions: #### This is the beats counter: ``` int counter = 0; ``` #### This indicates the success or failure to press the correct key on time: ``` int flag = 0; ``` #### This stores the value of the current key: ``` int val_buffer = val; int key_buffer = floor(rand(5)); ``` #### This keeps track of the score: ``` int score = 0; ``` # We have now reached the core of the game: ``` while(counter<540){ ``` ### If the correct key still hasn't been pressed: ``` if (val>val_buffer) { ``` #### This is the case of a successful key press: ``` if (key==key_buffer) { flag = 1; score = score+1; printf("SUCCESS: SCORE %d", score);}} if (beat_counter>=(beats[counter])*3) { ``` #### That is the case of a failure to match a note in time: ``` if (flag == 0) { printf("FAIL: SCORE %d", score);} ``` #### I then reset the variables: ``` flag = 0; val_buffer = val; ``` # The game asks for a new specific key press: ``` key_buffer = floor(1+rand()%5); printf("PRESS %d",key_buffer); counter=counter+1; } } ``` The game is finished once all the beats have been read: ``` printf("FINISHED!"); return 0; } ``` #### 4.1.4 QUARTUS VHDL code Here I present the different sets of modules in my VHDL project[30][29][36][3] on QUARTUS[4][13][14] [10][16][25][26] These are the architecture files of the project[15][5][24]: - nios\_system.sopc - nios\_system.vhd This is the main module of the project: • guitar\_top.vhd Here is a closer look at its contents: ``` entity guitar_top is port ( signal CLOCK_50 : in std_logic; SRAM_DQ : inout std_logic_vector(15 downto 0); SRAM_ADDR : out std_logic_vector(17 downto 0); This stores the current key: SRAM_UB_N, SRAM_LB_N, SRAM_WE_N, SRAM_CE_N, SRAM_OE_N : out std_logic ; These are the links to the Game Guitar: GPIO_0, - GPIO Connection 0 GPIO_1 : inout std_logic_vector(35 downto 0) - GPIO Connection 1 end guitar_top; architecture datapath of guitar_top is signal reset_n :std_logic; signal new_res:std_logic; signal audio_clock : unsigned(1 downto 0) := "00"; signal counter : unsigned(15 downto 0); process (CLOCK_50) begin if rising_edge(CLOCK_50) then if counter = x"ffff" then reset_n <= '1';</pre> reset_n <= '1'; else reset_n <= '0'; counter <= counter + 1; end if; end if;</pre> end process; process (CLOCK_50) begin if rising_edge (CLOCK_50) then audio_clock <= audio_clock + "l"; end if; end process;</pre> nios: entity work.nios_system port map ( clk => CLOCK_50, reset_n => reset_n, SRAM_ADDR_from_the_sram => SRAM_CE_N, SRAM_CE_N, from_the_sram => SRAM_CE_N, SRAM_DO_to_and_from_the_sram => SRAM_DO, SRAM_LB_N_from_the_sram => SRAM_DE_N, SRAM_OB_N_from_the_sram => SRAM_OE_N, SRAM_UB_N_from_the_sram => SRAM_UB_N, SRAM_UB_N_from_the_sram => SRAM_UB_N, SRAM_WE_N_from_the_sram => SRAM_WE_N, ``` ``` These are the links to Game Guitar key presses: SWITCH_lto_the_InputController_inst => GPIO_0(0), SWITCH_2_to_the_InputController_inst => GPIO_0(1), SWITCH_2_to_the_InputController_inst => GPIO_0(2), SWITCH_4_to_the_InputController_inst => GPIO_0(3), SWITCH_5_to_the_InputController_inst => GPIO_0(4)) ``` These modules enable to get the key presses from the user: - counter.vhd - DebounceCounter.vhd - · debouncer.vhd - pulser.vhd These are the key features of the file counter.vhd: ``` entity counter is port ( -Synchronous reset reset: in std_logic; clk: in std_logic; do: out unsigned(31 downto 0); di: in unsigned (31 downto 0) ... end counter; architecture arl of counter is signal value : unsigned(31 downto 0); begin process(clk) begin if(rising_edge(clk)) then ``` #### The value of the counter is modified at each time click: ``` else value <= value -1; value <= value -1; end if; end if; end process; do <= value; -copy value to the output end arl;</pre> ``` Now, I present the key features of debouncer.vhd: ``` entity debouncer is port ( clk : in std_logic; key_in : in std_logic; key_out : out std_logic; reset : in std_logic; architecture arl of debouncer is ``` "states" defines the different configurations that describe the current state of a button and its next state: ``` type states is (ZERO, ZERO_TO_ONE, ONE, ONE_TO_ZERO); ``` "states" thus enables me to define "state" and "next\_state": ``` signal state, next_state : states; signal do : unsigned(18 downto 0); signal reset_counter: std_logic; -to reset the counter begin ``` ``` C0: entity work.DebounceCounter port map ( clk => clk, reset => reset_counter, do => do); -FSM Strandard next_state => state process(clk) begin if(rising_edge(clk)) then if(reset='1') then state <= ZERO; else state <= next_state; end if; end process; ``` #### This is the computation of the next state: ``` process (state,key_in,do) begin next_state <= state; case state is</pre> ``` #### This is the case of the ZERO state: ``` -Signal generated: reset => 1, key_out => 0 when ZERO => reset_counter <= '1'; key_out <= '1'; if (key_in = '0') then next_state <= ZERO_TO_ONE; end if; ``` # This is the case of the ZERO\_TO\_ONE state: ``` -Signal generated: reset => 0, key_out => 0 when ZERO_TO_ONE => reset_counter <= '0'; key_out <= '1'; if (do >= 500_000) then next_state <= ONE; end if; ``` #### This is the case of the ONE state: ``` -Signal generated: reset => 1, key_out => 1 when ONE => reset_counter <= '1'; key_out <= '0'; if (key_in = '1') then next_state <= ONE_TO_ZERO; end if; ``` #### This is the case of the ONE\_TO\_ZERO state: ``` -Signal generated: reset => 0, key_out => 1 when ONE_TO_ZERO => reset_counter <= '0'; key_out <= '0'; if (do >= 500_000) then next_state <= ZERO; end if; end case; end case; end process; end arl; ``` #### I now present the main features of DebounceCounter.vhd: ``` entity DebounceCounter is port( -Synchronous reset reset : in std_logic; clk: in std_logic; do: out unsigned(18 downto 0) end DebounceCounter; architecture arl of DebounceCounter is signal value : unsigned(18 downto 0); begin reconstruction begin process(clk) begin if(rising_edge(clk)) then ``` ``` The value of the counter is modified at each time click: if (reset='1') then value <= (others => '0'); value <= (others => '0'); else value <= value + 1; end if; end process; do <= value; -copy value to the output end arl;</pre> ``` Finally, these are the key features of pulser.vhd. When the input signal switches to 1, it generates a pulse: ``` entity pulser is port clk : in std_logic; key_in : in std_logic; key_out : out std_logic; reset : in std_logic ); end pulser ; architecture Al of pulser is ``` "states" defines the different configurations that describe the pulse: ``` type states is (ZERO, ONE_PULSE, ONE_STANDBY); ``` "states" thus enables me to define "state" and "next\_state": ``` signal state, next_state : states; begin -FSM Strandard next_state => state process(clk) process(clk) begin if(rising_edge(clk)) then if( reset='1' ) then state <= ZERO;</pre> else state <= next_state;</pre> end if; end if; end process; ``` This is the computation of the next state: ``` process (state,key_in) begin next_state <= state; case state is</pre> ``` This is the case of the ZERO state: ``` -Signal generated 0 when ZERO => key_out <= '1'; if (key_in = '0') then next_state <= ONE_PULSE; end if, ``` This is the case of the ONE\_PULSE state: ``` -Signal generated 1 when ONE_PULSE => key_out <= '0'; next_state <= ONE_STANDBY; ``` This is the case of the ONE\_STANDBY state: ``` -Signal generated: when ONE_STANDBY => key_out <= '1'; if (key_in = '1') then next_state <= ZERO; end if; end case; end process; end Al; ``` The complete links between the uses of all these files are described more precisely in the following paragraphs, which present the input controllers. Moreover, these modules convert the key presses from the user to interruptions: - InputController.vhd - InputController\_inst.vhd - InputController2\_inst.vhd - InputController3\_inst.vhd - InputController4\_inst.vhd - InputController5\_inst.vhd I use five instances of the InputController vhdl file. I created them following the tutorial[1] from the class website. There is one input controller per button of the Game Guitar. In each of these files the counter, debouncer and pulser vhdl files are called in oreder to detect key presses and thus send an interruption signal. ``` entity InputController is port ( -Avalon clk : in std_logic; reset_n : in std_logic; read : in std_logic; write : in std logic; chipselect : in std_logic; address : in unsigned(9 downto 0); readdata : out unsigned(15 downto 0); writedata : in unsigned(15 downto 0); inter : out std_logic; These are the 5 switches of the Game Guitar SWITCH_1 : in std_logic; SWITCH_2 : in std_logic; SWITCH_3 : in std_logic; SWITCH 4 : in std logic: SWITCH_5 : in std_logic end InputController; architecture rtl of InputController is "states" defines the different configurations of the input controller: type states is (IDLE, PRESSED, WAITST); "states" thus enables me to define "state" and "next_state": signal state, next_state : states; signal we:std Logic; signal reset:std_logic; signal counter: integer; The following is a bunch of signals for the button. The button clicks are first debounced and then pulsed. The naming follows this convention: – Initial SWITCH_1: this is the original signal. - Debounced DSWITCH_1: The debouncing has been applied. Here is the new version of our example: - Pulsed PSWITCH_1: The pulser has been applied in order to avoid redundant in- ``` terruption. This is the final version of our example: \_\_\_\_\_- ``` -Switch 1 signal DSWITCH_1:std_logic; signal PSWITCH_1:std_logic; -Switch 2 signal DSWITCH_2:std_logic; signal PSWITCH_2:std_logic; -Switch 3 signal DSWITCH_3:std_logic; signal PSWITCH_3:std_logic; -Switch 4 signal DSWITCH_4:std_logic; signal PSWITCH_4:std_logic; signal PSWITCH_5:std_logic; -Switch 5 signal DSWITCH_5:std_logic; signal PSWITCH_5:std_logic; ``` #### This is the debouncer: ``` component debouncer is port( clk : in std_logic; key_in : in std_logic; key_out : out std_logic; reset : in std_logic ); end component debouncer; ``` ### This is the pulser: ``` component pulser is port( clk : in std_logic; key_in : in std_logic; key_out : out std_logic; reset : in std_logic ); end component pulser; begin -Reset reset <= not reset_n; -Write enable we <= '1' when chipselect ='1' and write='1' else '0';</pre> ``` # These are the mappings of the debouncer: ``` D1: debouncer port map(clk,SWITCH_1,DSWITCH_1,reset); D2: debouncer port map(clk,SWITCH_2,DSWITCH_2,reset); ``` ``` D3: debouncer port map(clk,SWITCH_3,DSWITCH_3,reset); D4: debouncer port map(clk,SWITCH_4,DSWITCH_4,reset); D5: debouncer port map(clk,SWITCH_5,DSWITCH_5,reset); ``` #### "states" thus enables me to define "state" and "next\_state": ``` P1: pulser port map(clk,DSWITCH_1,PSWITCH_1,reset); P2: pulser port map(clk,DSWITCH_2,PSWITCH_2,reset); P3: pulser port map(clk,DSWITCH_3,PSWITCH_3,reset); P4: pulser port map(clk,DSWITCH_4,PSWITCH_4,reset); P5: pulser port map(clk,DSWITCH_5,PSWITCH_5,reset); -FSM Strandard next_state => state process(clk) if(rising_edge(clk)) then if( reset_n='0' ) state <= IDLE; state <= next_state; if (state = PRESSED) then counter <=0; end if; end if; end if; end process; -Combinational process process (state, SWITCH_1, we) begin -By default reset the interuption signal inter <= '0'; next_state <= state; case state is ``` ``` when IDLE => inter <='0'; if (PSWITCH_1 = '0' or PSWITCH_2 = '0' or PSWITCH_3 = '0' or PSWITCH_4 = '0' or PSWITCH_5 = '0') then next_state <= PRESSED; end if; ``` A button has been pressed. I stay into this PRESSED state until the interuption has been cleared. ``` when PRESSED => inter <='1'; if (we='1') ``` ``` then next_state <= WAITST; end if; when WAITST => inter <='0'; if (counter > 30000) then next_state <= IDLE; end if; end case; end process; end rtl;</pre> ``` # This is the main organization of all the instances of InputController: ``` chipselect => chipselect, clk => clk, read => read, reset_n => reset_n, write => write, writedata => writedata ); -vhdl renameroo for output signals inter <= internal_inter; -vhdl renameroo for output signals readdata <= internal_readdata; end europa;</pre> ``` The last sets of files are mostly pre-written files already available in the class labs. Here are the files for the sram[34]: - de2\_sram\_controller.vhd - sram.vhd And here is the file for the video display[33] and the audio: - de2\_i2c\_av\_config.v - de2\_i2c\_controller.v - de2\_wm8731\_audio.vhd - jtag\_uart.vhd These are other files, which are related to the cpu: - cpu.vhd - cpu\_jtag\_debug\_module.vhd - cpu\_jtag\_debug\_module\_wrapper.vhd - cpu\_test\_bench.vhd This is an additional file related to my early tests of the audio of the game: • lab3\_audio.vhd #### 4.2 Timing design In this subsection, I present the Timing design of the project[27]. #### 4.2.1 Extraction of the beats The extraction of the beats is done using LabRosa[35]. It is run and stored beforehand in the project. More precisely, given a mp3 song, the MATLAB code extracts the beats of the song and stores them in a text file. This text file is then being processed by a PYTHON code that converts it to a format recognizable in C. Here is an excerpt of the README for LabROSA-coversongID. "See http://labrosa.ee.columbia.edu/projects/coversongs/ for more info." "Key functions: - t = tempo(d,sr); estimates the tempo in BPM of audio waveform d at sample rate sr - b = beat(d,sr); estimates the beat times (in sec) of audio waveform d at sample - qlist = calclistftrs(querylistfilename); calculates beat-synchronous chroma feature matrices for all the way or mp3 files listed, one per line, in the named file, returning a list of calculated feature files, then... - R = coverTestLists(qlist); compares each feature file named in the qlist against every item and returns R as a square matrix of distance between each pair." #### 4.3 Correct timing of the beats The beats are stored inside the main C program: int beats[] = {0x00b4,0x00c8,0x00f0,0x0116,0x0141,0x016a,0x0193,0x01bb... 0x4b71,0x4b98,0x4bc0,0x4be6,0x4c0d,0x4c33,0x4c5d,0x4c82,0x4cad,0x4cd7}; They are then accessed at each incrementation of the counter: ``` int counter = 0; int flag = 0; int val_buffer = val; int key_buffer = floor(rand(5)); int score = 0; while(counter<540){ if (flag!=1){ if (xal_buffer){ if (key=key_buffer){ flag = 1; score = score+1; printf("SUCCESS: SCORE %d", score);}} if (flag == 0){ printf("FAIL: SCORE %d", score);} flag = 0; val_buffer = val; key_buffer = floor(1+rand()%5); printf("PRESS %d", key_buffer); counter=counter+1; } }</pre> ``` ``` } printf("FINISHED!"); return 0; } ``` #### 4.3.1 Use of interruptions to indicate that the guitar has been pressed The interruptions implementation tutorial by Professor Stephen Edwards is available at [1]. $_{//\ I}$ set the displayed key each time val is incremented. ``` // I set the displayed key each time val is incremented. static void irqhandler (void * context, alt_u32 id) val ++; key = 1; IOWR_8DIRECT(INPUTCONTROLLER_INST_BASE, 0, 0); // reset request } static void input_isr ( void* context, alt_u32 id){ valz++; IOWR_16DIRECT(INPUTCONTROLLER_INST_BASE, 0,0); return; ``` The interruptions are then exploited inside the main() by using "alt\_irq\_register": #### 4.4 Additional tracks of study #### 4.4.1 Alternative beats handling system This next set of files did not make it to the final version of the project. However, It has been a consequent track of study which I wish to mention. The timer files were a custom timing function I had design to keep track of the occurences of the beats directly inside the VHDL code. The sixth instance of InputController was to send a notification when a beat was appearing. However, I decided to deal with the beats directly in the NIOS II C code in the end. The files related to this particular track of study are the following: • InputController6\_inst.vhd - timer.vhd - timer.vhdl #### 4.4.2 Storage of the song Concerning the storage of the song, I first used the SDRAM[28]. The beats controller and the music controller still had to be synchronized. Then, I tried to use the flash memory[2] instead. The beats controller and the music controller still had to be synchronizedas well. #### 4.4.3 Playing the song For this part, I reused my work of the lab3 assignment where I dealt with playing audio sounds. #### 4.4.4 Video display using sprites There was some early work done on the display of sprites. I included the resluting files in the "ADDITIONAL TRACKS OF STUDY" folder of the final project. # 5 Hardware In this section, I give a closer look at the hardware that was used in the project. # 5.1 FPGA The main hardware of the project is the FPGA[7][8][9][6]. Altera DE2 Development and Education board (altera.com/education/univ/images/boards/de2.jpg) # 5.2 Game Guitar I have customized a Guitar Hero controller to become the Game Guitar. (i14.ebayimg.com/01/i/001/22/73/0b2412.JPG) Connexion between the two band wires of the FPGA $_{\mbox{\tiny (imi2108)}}$ Front view of the connexion between the second band wire of the FPGA and the ethernet port of the Game Guitar Back view of the connexion between the second band wire of the FPGA and the ethernet port of the Game Guitar Front view of the connexion of the ethernet cable to the Game Guitar $\frac{1}{(mn)^2 108)}$ Back view of the connexion of the ethernet cable to the Game Guitar $_{\text{(inil2108)}}$ # 5.3 VGA display The VGA dispaly I used for this project is one of the displays that are available in the Embedded Systems laboratory. This is where I use the console of the NIOS II interface. $VGA\ display \\ {\it (cclonline.com/images/MediaPool/PRQId111fvkKq4fqdrRmYg-3d-3d\_LargeProductImage.jpg)}$ # 6 Experiences and issues in implementation In this section, I present the experiences and issues in implementation, including the difficult parts. ### 6.1 Playing the song At the beginning of the project, I ran tests with 1 second samples form a song in the VHDL code of lab3. However, it was hard to make oneself a sure opinion of the result as the playtime was so short. I had thought about several ways to store the song: - Store it in the SDRAM - Store it in the Flash memory - Use a raw sound from an external source After trying all three possibilities, I decided to use the last one. This decision was based on project time constraints. ### **6.2** Storage using the SDRAM WHen implementing the SDRAM, I had to work on a step by step basis. First of all, I followed the tutorial for the SDRAM setup. Once the SDRAM had been added to the project, I still had write on it and read it. These two parts were the trickiest ones. I had to carefully study of the memory locations where indexed so that each element of the song would fit inside the SDRAM without any risk of overlapping or gaps. I thus had to run tests of understand which address I was accessing and how many bits I was reading or writing when I was using a specific address. #### 6.3 Bugs solving It was generally difficult to trace the source of a crash, especially in VHDL. The debugging information was scarce so it required a lot of time to locate the source of a bug. It often involved backtracking the source of the crash through multiple files. Debugging was easier using C. However, missing libraries were often an issue, and finding these libraries was not always a solution to some of the problems that I wanted to solve. This was especially true when I was dealing with the time element of this project. ### 6.4 Merging several parts of the project Merging several parts of the project was always tricky. Generally, I was working on two aspects of the project at the same time. So when both of them were done, it was time to join them so that the project could continue to go on. What I did was to take the more complex of the two works, and progressively add the elements of the other one inside it I first added all the new files. Then I modifiedd the files that were common to both these work by adding the lines of code of the second work that were absent from the first one. This often implied a consequent debugging phase, due to the apparition of bugs that were specific to the coexistence of these two works in the same project. # 7 Summary including lessons learned In this section, I provide a summary of the project as well as a listing of what lessons I learned during this project. I also give some advice for future projects. ### 7.1 Summary of the project The global objectives of the project have been fulfilled: - building the hardware for the Game Guitar, - developing the VHDL and C software, - having the game running. More precisely, these features are available in the final version of the project: - Hardware of the Game Guitar - Detection of the input of the game guitar - Extraction of the beats of a song - Asking for the correct key presses, based on the beats - Analysis of the correctness of the key presses of the player - Keeping track of the score ### 7.2 Lessons learned - Start the project as early as possible. - Do not venture into too many directions at once; it is more efficient to stay focused on a limited number of tasks. - Code and debug small step per small step. - When a specific track of study progressively seems to be a dead end, find a new solution as early as possible. - Synchronize all the parts of the project as soon as possible. - Carefully plan ahead when to come to the Embedded Systems laboratory in order to have an available workstation and always keep in mind that other students need these workstations as well so it is imperative to share ressources. That way, all projects make progress and the mood in the laboratory is much more enjoyable. - Make regular copies of the global projects in order to be able to go back to a previous version in case the current one get corrupted by a bug too difficult to find quickly. - Do not hesitate to ask the teaching Assistants for information when starting to study a new programming language. - Be very careful with the SOPC builder. - The most important lesson of all: enjoy your project! Enjoy the Awesome Guitar Game! # 7.3 Some advice for future projects - If it is your first time coding with VHDL or C, be very careful in the first days of the project and regularly test your work. - As I said previously, future students should keep in mind that other students need the workstations of the Embedded Systems laboratory as well so it is imperative to share ressources. That way, all projects make progress and the mood in the laboratory is much more enjoyable. - Do not hesitate to refer repeatedly to the previous years projects and projects reports [17][18][19][20][21][22]. They contain very valuable information from students who already saw an Embedded System Design project through. # 8 Listing of all source code Here is a complete listings of every file I wrote for the project. It includes C source, VHDL source, and things such as .mhs files. I did not include any file that was generated automatically. I mad sure of that by applying "rm -rf db incremental\_db .rpt .done .summary .smsg .pin .qdf .pof" beforehand. I did not include the .bak files either. ### 8.1 MATLAB source code - beatavg.m - beat.m - calclistftrs.m - chromagram\_E.m - chromagram\_IF.m - chromagram\_P.m - chrombeatftrs.m - chromnorm.m - chrompwr.m - chromrot.m - chromxcorr.m - coverDistMxLists.m - coverFtrExLists.m - coverTestLists.m - distmatrixwrite.m - fexist.m - fft2chromamx.m - fft2melmx.m - history-bragg-autoco.m - history-golddust-xcorr.m - hz2octs.m - ifgram.m - ifptrack.m - listfileread.m - listfilewrite.m - localmax.m - mkblips.m - mp3read.m - mymkdir.m - octs2hz.m - tempo.m - testlist.m - test.m ### 8.2 PYTHON source code - toHexArray.py - encode.py - randomize.py - shortest\_time\_dist.py #### 8.3 C source code • hello\_world.c ## 8.4 VHDL source code - AWESOME\_GUITAR.qpf - AWESOME\_GUITAR.qws - AWESOME\_GUITAR\_TOP.dpf - AWESOME\_GUITAR\_TOP.jdi - AWESOME\_GUITAR\_TOP.qsf - $\bullet \ \ AWESOME\_GUITAR\_TOP.sof$ - counter.vhd - cpu.ocp - cpu.vhd - cpu\_jtag\_debug\_module.vhd - cpu\_jtag\_debug\_module\_wrapper.vhd - cpu\_ociram\_default\_contents.mif - cpu\_rf\_ram.mif - cpu\_test\_bench.vhd - DebounceCounter.vhd - debouncer.vhd - de2\_i2c\_av\_config.v - de2\_i2c\_controller.v - de2\_sram\_controller.vhd - de2\_sram\_controller\_hw.tcl - de2\_wm8731\_audio.vhd - guitar\_top.vhd - InputController.vhd - InputController\_hw.tcl - InputController\_inst.vhd - InputController2\_inst.vhd - InputController3\_inst.vhd - InputController4\_inst.vhd - InputController5\_inst.vhd - InputController6\_inst.vhd - jtag\_uart.vhd - nios\_system.bsf - nios\_system.ptf - nios\_system.qip - nios\_system.sopc - nios\_system.vhd - nios\_system\_generation\_script - nios\_system\_log.txt - nios\_system.ptf.pre\_generation\_ptf - nios\_system\_setup\_quartus.tcl - pulser.vhd - sopc\_builder\_log.txt - sram.vhd - timer.vhd - timer.vhdl - timer\_hw.tcl - timer\_inst.vhd ### **Conclusion** Once again, I wish to thank Professor Stephen Edwards for all his help throughout this entire project and for making this class a very enjoyable experience. It has been most instructive and gave me more insight in dealing with some specific types of hardware. In the end, I have designed a video game that enables the user to match the notes that are asked from him on a VGA display using a game guitar while his score is being modified based on how successful he is. Coding and debuging this software has been a really entertaining activity. It enabled me to discover VHDL, reinforce my skills in C, and continue to use MATLAB and PYTHON. Using, modifying and building hardware by myself has also been a very enjoyable experience. This gave a "hands-on" feel to the project that enabled to see the physical effects of my work. As a matter of fact, it was the first time I was welding again since middle school. Right now, this project enables the player to match the required notes using the game guitar I designed, all the while following instructions and his score using a VGA display. For students who will take this class in the future and who wish to do do a project based on this one, here are some hints on what to work on, using my work as a basis. The first element worth implementing is a more developed visual interface for the game, using sprites. It would also be nice to have several different songs available instead of just one. Finally, another cool feature would be to introduce a multiplayer mode. # **Bibliography** - [1] Tutorial: Creating peripherals with interrupts in altera's sope builder author =. - [2] S29al032d; 32 megabit cmos 3.0 volt-only flash memory; 4 m x 8-bit uniform sector; 4 m x 8-bit/2 m x 16-bit boot sector; data sheet preliminary. (S29AL032D\_00; Revision A; Amendment 5), Sep 2005. - [3] Avalon memory-mapped interface specification. (3.3), May 2007. - [4] Quartus ii version 7.2 handbook. (Volume 3: Verification), May 2007. - [5] Pong P. Chu. Embedded sopc design with nios ii processor and vhdl examples. 2011. - [6] Altera Corporation. Cyclone ii device handbook. (Volume 1). - [7] Altera Corporation. De2 development and education board. - [8] Altera Corporation. De2 development and education board. (3.3). - [9] Altera Corporation. De2 development and education board; user manual. - [10] Altera Corporation. Introduction to the quartus(R) ii software. (Version 7.2). - [11] Altera Corporation. Nios ii processor reference handbook. - [12] Altera Corporation. Nios ii software developer's handbook. - [13] Altera Corporation. Quartus ii version 7.2 handbook. (Volume 2: Design Implementation and Optimization). - [14] Altera Corporation. Quartus ii version 7.2 handbook. (Volume 1: Design and Synthesis). - [15] Altera Corporation. Quartus ii version 7.2 handbook. (Volume 4: SOPC Builder). - [16] Altera Corporation. Quick start guide for quartus ii software. - [17] cs.columbia.edu/ sedwards/classes/2006/4840/index.html. - [18] cs.columbia.edu/ sedwards/classes/2007/4840/index.html. - [19] cs.columbia.edu/ sedwards/classes/2008/4840/index.html. - [20] cs.columbia.edu/ sedwards/classes/2009/4840/index.html. - [21] cs.columbia.edu/ sedwards/classes/2010/4840/index.html. - [22] cs.columbia.edu/ sedwards/classes/2011/4840/index.html. - [23] cs.columbia.edu/ sedwards/classes/2012/4840/index.html. - [24] Stephen A. Edwards. Introduction to the altera sopc builder. - [25] Stephen A. Edwards. Quartus ii introduction using vhdl design. - [26] Stephen A. Edwards. Quartus ii simulation with vhdl designs. - [27] Stephen A. Edwards. Timing considerations with vhdl-based designs. - [28] Stephen A. Edwards. Using the sdram memory on altera's de2 board with vhdl design. - [29] Stephen A. Edwards. Writing vhdl for rtl synthesis. *Columbia University*, January 2011. - [30] esd.cs.ucr.edu/labs/tutorial/. - [31] http://www.laserist.org/. - [32] hub.guitarhero.com/. - [33] Texas Instruments. 9900; tms9918a/tms9928a/tms9929a; video display processors. 1982. - [34] Inc. Integrated Circuit Solution. Is42s8800/is42s8800l is42s16400/is42s16400l; 2(1)m words x 8(16) bits x 4 banks (64-mbit); synchronous dynamic ram. - [35] labrosa.ee.columbia.edu/projects/coversongs/. - [36] Mark Zwolinski. Digital system design with vhdl. *Pearson/Prentice-Hall*, January 2004. ### **Annexes** Here are the C and VHDL source files I wrote or modified. I did not include any automatically-generated files in this report. I mad sure of that by applying "rm -rf db incremental\_db .rpt .done .summary .smsg .pin .qdf .pof" beforehand. I did not include the .bak files either. #### MATLAB source code #### beatavg.m ``` function X = beatavg(Y,bts) % X = beatavg(Y,bys) % Calculate average of columns of Y according to grid defined % (real-valued) column indices in vector bts. % For folding spectrograms down into beat-sync features. % Dose-09-26 dpwe@ee.columbia.edu % beat-based segments %bts = beattrack(d,sr); nbts = length(bts); bttime = mean(diff(bts)); % map beats to specgram slices ncols = size(Y,2); coltimes = [0:(ncols-1)]; cols2beats = zeros(nbts, ncols); btse = [bts,max(coltimes)]; for b = l:nbts cols2beats(b,:) = ((coltimes >= btse(b)) & (coltimes < btse(b+1)))*1/(btse(b+1)-btse(b)); end % The actual desired output X = Y * cols2beats';</pre> ``` #### beat.m ``` tightness = tightness(1); else alpha = 0.8 if tightness == 0; tightness = 6; end \mbox{\$} Have we been given an envelope (nonnegative waveform) if min(d) >= 0 onsetenv = d; sgsrate = sr; disp(['beat: treating input as onset strength envelope']); else onsetenv = []; end % debug/plotting options plotlims = []; if length(doplot) > 1 % specify zoom—in limits too plotlims = doplot; doplot = 1; if doplot > 0; debug = 1; else debug = 0; end b = []; \$ Select tempo search either with startbpm = 0 (means use defaults) \$ or startbpm > 0 but temposd > 0 too (means search around startbpm) \$ If onsetenv is empty, have to run tempo too to convert waveform \$ to onsetenv, but we might not use the tempo it picks. if startbpm == 0 | temposd > 0 | length(onsetenv) == 0 if startbpm == 0 tempomean = 120; tempomean = startbpm; end if temposd == 0 temposd = 0.7; % Subfunction estimates global BPM; returns 'onset strength' % waveform onsetenv * If we were given an onsetenv as input, will use that t,xcr,D,onsetenv,sgsrate = tempo(d,sr,tempomean,temposd,onsetenv,debug); % tempo.m returns the top-2 BPM estimates; use faster one for % beat tracking if (startbpm == 0 | temposd > 0) startbpm = \max(t([1\ 2])); end if debug == 1 % plot the mel-specgram tt = [1:length(onsetenv)]/sgsrate; subplot(411) imagesc(tt,[1 40],D); axis xy subplot(412) subplot (412) plot(tt,onsetenv); % convert startbpm to startpd startpd = (60*sgsrate)/startbpm; %disp(['startpd=',num2str(startpd)]); pd = startpd; % Smooth beat events templt = exp(-0.5*((-pd:pd/(pd/32)).2)); localscore = conv(templt,onsetenv); localscore = localscore(round(length(templt)/2)+[1:length(onsetenv)]); % backlink(time) is index of best preceding time for this point % cumscore(time) is total cumulated score to this point backlink = zeros(1,length(localscore)); cumscore = zeros(1,length(localscore)); % search range for previous beat prange = round(-2*pd):-round(pd/2); starting = 1; for i = 1:length(localscore) timerange = i + prange; % Are we reaching back before time zero? zpad = max(0, min(1-timerange(1),length(prange))); % Search over all possible predecessors and apply transition % sealth over all possess % weighting scorecands = txwt .* [zeros(1,zpad),cumscore(timerange(zpad+1:end))]; ``` ``` % Find best predecessor beat vv,xx = max(scorecands); % Add on local score cumscore(i) = alpha*vv + (1-alpha)*localscore(i); $ special case to catch first onset $ if starting == 1 & localscore(i) > 100*abs(vv) if starting == 1 & localscore(i) < 0.01*max(localscore); backlink(i) = -1; else backlink(i) = timerange(xx); $ prevent it from resetting, even through a stretch of silence starting = 0; end</pre> end %%%% Backtrace % Cumulated score is stabilized to lie in constant range, % so just look for one near the end that has a reasonable score medscore = median(cumscore(localmax(cumscore))); bestendx = max(find(cumscore .* localmax(cumscore) > 0.5*medscore)); while backlink(b(end)) > 0 b = [b,backlink(b(end))]; b = fliplr(b); % return beat times in secs b = b / sgsrate; % Debug visualization if doplot == 1 subplot(411) hold on; plot([b;b], [0;40]*ones(1,length(b)),'w'); hold off; subplot(412) hold one; hold on; plot([b;b],[-5;20]*ones(1,length(b)),'g'); hold off; % redo 3rd pane as xcorr with templt subplot(413) tt = [1:length(localscore)]/sgsrate; plot(tt,localscore); hold on; plot([b;b],[min(localscore);max(localscore)]*ones(1,length(b)),'g'); hold off if length(plotlims) > 0 if length(plot1) for i = 1:3; subplot(4,1,i) ax = axis; ax([1 2]) = plotlims; axis(ax); end end ``` #### calclistftrs.m This is a file that I did not modify from its original version. #### chromagram\_E.m ``` function Y = chromagram_E(d,sr,fftlen,nbin,f_ctr,f_sd) % Y = chromagram_E(d,sr,fftlen,nbin) % Calculate a "chromagram" of the sound in d (at sampling rate sr) % Use windows of fftlen points, hopped by ffthop points % Divide the octave into nbin steps % Weight with center frequency f_ctr (in Hz) and gaussian SD f_sd (in octaves) % 2006-09-26 dpwe@ee.columbia.edu if nargin < 3; fftlen = 2048; end if nargin < 4; nbin = 12; end if nargin < 5; f_ctr = 1000; end if nargin < 6; f_sd = 1; end fftwin = fftlen/2; ffthop = fftlen/4; % always for this D = abs(specgram(d,fftlen,sr,fftwin,(fftwin-ffthop))); A0 = 27.5; % Hz A440 = 440; % Hz f_ctr_log = log(f_ctr/A0) / log(2);</pre> ``` ``` \label{eq:cm} $$CM = fft2chromamx(fftlen, nbin, sr, A440, f_ctr_log, f_sd); $$Chop extra dims $$CM = CM(:,l:(fftlen/2)+1); Y = CM * D; ``` ### chromagram\_IF.m This is a file that I did not modify from its original version. #### chromagram\_P.m ``` function Y = chromagram_P(d,sr,fftlen,nbin,f_ctr,f_sd) % Y = chromagram_E(d,sr,fftlen,nbin) % Calculate a "chromagram" of the sound in d (at sampling rate sr) % Use windows of fftlen points, hopped by ffthop points % Divide the octave into nbin steps % Weight with center frequency f_ctr (in Hz) and gaussian SD f_sd (in octaves) % 2006-09-26 dpwe@ee.columbia.edu if nargin < 3; fftlen = 2048; end if nargin < 4; nbin = 12; end if nargin < 5; f_ctr = 1000; end if nargin < 6; f_sd = 1; end</pre> fftwin = fftlen/2; ffthop = fftlen/4; % always for this D = abs(specgram(d, fftlen, sr, fftwin, (fftwin-ffthop))); A0 = 27.5; % Hz A440 = 440; % Hz f_ctr_log = log(f_ctr/A0) / log(2); CM = fft2chromamx(fftlen, nbin, sr, A440, f_ctr_log, f_sd); % Chop extra dims CM = CM(:,1:(fftlen/2)+1); \begin{tabular}{ll} \$ \ \, Keep \ \, only \ \, local \ \, maxes \ \, in \ \, freq \\ Dm = (D > D([1,[1:nr-1]],:)) & (D >= D([[2:nr],nr],:)); \\ Y = CM * (D.*Dm); \\ \end{tabular} ``` #### chrombeatftrs.m ``` function [F,bts] = chrombeatftrs(d,sr,f_ctr,f_sd,type) % [F,bts] = chrombeatftrs(D,SR,F_CTR,F_SD,TYPE) % F returns a feature vector of beat-level chroma features (12 % rows x n time step columns). bts returns the times of all the % beats. % New version separates out chroma calculation * TYPE selects chroma calculation type; 1 (default) uses IF; % 2 uses all FFT bins, 3 uses only local peaks (a bit like Emilia). % 2006-07-14 dpwe@ee.columbia.edu % 2006-U/-14 opwetee.columbla.edu % Copyright (c) 2006 Columbia University. % % This file is part of LabROSA-coversongID % % LabROSA-coversongID is free software; you can redistribute it and/or modify % it under the terms of the GNU General Public License version 2 as % published by the Free Software Foundation. % % LabROSA-coversongID is distributed in the hope that it will be useful, but % WITHOUT ANY WARRANTY; without even the implied warranty of % MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU % General Public License for more details. % % You should have received a copy of the GNU General Public License % along with LabROSA-coversongID; if not, write to the Free Software % Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA % 02110-1301 USA % % See the file "COPYING" for the text of the license. \label{eq:continuous} \begin{tabular}{ll} if nargin < 4; f\_sd = 1; end \\ if nargin < 5; type = 1; end \\ \end{tabular} tempomean = 240; temposd = 1.5; % Try beat tracking now for quick answer bts = beat(d,sr,[tempomean temposd],[6 0.8],0); $ Calculate frame-rate chromagram fftlen = 2 {round(log(sr*(2048/22050))/log(2))); nbin = 12; if type == 2 Y = chromagram_E(d,sr,fftlen,nbin,f_ctr,f_sd); elseif type == 3 ``` ``` Y = chromagram_P(d,sr,fftlen,nbin,f_ctr,f_sd); else Y = chromagram_IF(d,sr,fftlen,nbin,f_ctr,f_sd); end ffthop = fftlen/4; sgsrate = sr/ffthop; F = beatavg(Y,bts*sgsrate); ``` #### chromnorm.m ``` function [N,S] = chromnorm(F) % [N,S] = chromnorm(F) % Normalize each column of a chroma ftrvec to unit norm % so cross-correlation will give cosine distance % S returns the per-column original norms, for reconstruction % 2006-07-14 dpwe@ee.columbia.edu [nchr, nbts] = size(F); S = sqrt(sum(F.2)); N = F./repmat(S+(S==0), nchr, 1); ``` #### chrompwr.m ``` function Y = chrompwr(X,P) % Y = chrompwr(X,P) raise chroma columns to a power, preserving norm % 2006-07-12 dpwe@ee.columbia.edu [nbins,nframes] = size(X); % norms of each input col CMn = repmat(sqrt(sum(X.2)),nbins,1); CMn(CMn = 0) = 1; % normalize each input col, raise to power CMp = (X./CMn).P; % norms of each resultant column CMpn = repmat(sqrt(sum(CMp.2)),nbins,1); CMpn(CMpn = 0) = 1; % rescale cols so norm of output cols match norms of input cols Y = CMn.*(CMp./CMpn); ``` #### chromrot.m ``` function Y = chromrot(X,N) % Y = chromrot(X,N) % Rotate each column of chroma feature matrix X down by N % semitones. % 2006-07-15 dpwe@ee.columbia.edu [nr,nc] = size(X); Y = X(1+rem([0:(nr-1)]+N+nr,nr),:); ``` #### chromxcorr.m ``` function r = chromxcorr(A,F,L) % r = chromxcorr(A,F,L) % r = chromxcorr(A,F,L) % Cross-correlate two chroma ftr vecs in both time and % transposition % Both A and F can be long, result is full convolution % (length(A) + length(F) - 1 columns, in F order). % L is the maximum lag to search to - default 100. % of shorter, 2 = by length of longer % Optimized version. % 2006-07-14 dpwe@ee.columbia.edu % Copyright (c) 2006 Columbia University. % % This file is part of LabROSA-coversongID % % LabROSA-coversongID is free software; you can redistribute it and/or modify % it under the terms of the GNU General Public License version 2 as % published by the Free Software Foundation. % % LabROSA-coversongID is distributed in the hope that it will be useful, but % WITHOUT ANY WARRANTY; without even the implied warranty of % MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU % General Public License for more details. % % You should have received a copy of the GNU General Public License % along with LabROSA-coversongID; if not, write to the Free Software % Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA % 02110-1301 USA ``` ``` % % See the file "COPYING" for the text of the license. if nargin < 3; L = 100; end [nchr.nbts1] = size(A); nchr2.nbts2 = size(F); if nchr = nchr2 error('chroma sizes dont match'); end r = zeros(nchr, 2*L+1); for i = 1:nchr rr = 0; for j = 1:nchr rr = rr + xcorr(F(1+rem(j+i-2,nchr),:),A(j,:),L); end r(i,:) = rr; end % Normalize by shorter vector so max poss val is 1 r = r/min(nbts1,nbts2);</pre> ``` #### coverDistMxLists.m This is a file that I did not modify from its original version. #### coverTestLists.m This is a file that I did not modify from its original version. ### distmatrixwrite.m ``` function distmatrixwrite(matrix,rownames,colnames,filename,tag) % distmatrixwrite(matrix,rownames,colnames,filename,tag) % Write a distance matrix % 2006-08-06 dpwe@ee.columbia.edu if nargin < 5 tag = 'dpweDefault'; end fid = fopen(filename, 'w'); fprintf(fid, '%s n', tag); usecolnames = zeros(length(colnames)); nn = 0; for i = 1:length(rownames); nn = nn+1; fprintf(fid, '%d t%s n', nn, rownamesi); % if this name also occurs as a col, remember we don't need it usecolnames(strcmp(colnames, rownames(i))) = nn; end for i = 1:length(colnames); if usecolnames(i) == 0 nn = nn+1; fprintf(fid, '%d t%s n', nn, colnamesi); usecolnames(i) == 0 nn = nn+1; fprintf(fid, '%d t%s n', nn, colnamesi); usecolnames(i) = nn; end end % Matrix heading fprintf(fid, '%d', usecolnames); fprintf(fid, '%d', usecolnames(i)); end fprintf(fid, '%d', usecolnames(i)); fprintf(fid, '%d', usecolnames(i)); fprintf(fid, '%d', i); i);</pre> ``` #### fexist.m ``` function E = fexist(F) % E = fexist(F) returns 1 if file F exists, else 0 % 2006-08-06 dpwe@ee.columbia.edu ``` ``` x = dir(F); E = length(x); ``` ### fft2chromamx.m This is a file that I did not modify from its original version. #### fft2melmx.m This is a file that I did not modify from its original version. #### history-bragg-autoco.m This is a file that I did not modify from its original version. #### history-golddust-xcorr.m This is a file that I did not modify from its original version. #### hz2octs.m ``` function octs = hz2octs(freq, A440) % octs = hz2octs(freq, A440) % Convert a frequency in Hz into a real number counting % the octaves above A0. So hz2octs(440) = 4.0 % Optional A440 specifies the Hz to be treated as middle A (default 440). % 2006-06-29 dpwe@ee.columbia.edu for fft2chromamx if nargin < 2; A440 = 440; end % A4 = A440 = 440 Hz, so A0 = 440/16 Hz octs = log(freq./(A440/16))./log(2);</pre> ``` #### ifgram.m This is a file that I did not modify from its original version. #### ifptrack.m This is a file that I did not modify from its original version. #### listfileread.m ``` function [L,N] = listfileread(F) % [L,N] = listfileread(F) Read a list of per-line items % F is a file containing a list of items, one per line. % Return L as a cell array, with one item per line, N as the % number of items. % If F is not found, return empty L and N == -1 (instead of 0). % 2006-08-06 dpwe@ee.columbia.edu for MIREX 06 N = -1; L = []; if fexist(F) == 1 fid = fopen(F); nitems = 0; while 1 tline = fgetl(fid); if ischar(tline), break, end nitems = nitems+1; Lnitems = tline; end fclose(fid); N = nitems; ``` #### listfilewrite.m ``` function N = listfilewrite(L, F) % N = listfilewrite(L, F) Write a list of items to a file % L is a cell array of strings. Write to file F, one per line. % N returns the number of items successfully written. % 2006-08-06 dpwe@ee.columbia.edu for MIREX 06 fid = fopen(F, 'w'); nit = length(L); for i = l:nit fprintf(fid, '%s n', Li); end fclose(fid); ``` #### localmax.m ``` function m = localmax(x) % return 1 where there are local maxima in x (columnwise). % don't include first point, maybe last point [nr,nc] = size(x); if nr == 1 lx = nc; elseif nc == 1 lx = nr; x = x'; else lx = nr; end if (nr == 1) || (nc == 1) m = (x > [x(1),x(1:(1x-1))]) & (x >= [x(2:1x),1+x(1x)]); if nc == 1 % retranspose m = m'; end else % matrix lx = nr; m = (x > [x(1,:);x(1:(1x-1),:)]) & (x >= [x(2:1x,:);1+x(1x,:)]); end ``` #### mkblips.m ``` function d = mkblips(b,sr,1) % d = mkblips(b,sr,1) % Make a blip track at the set of times in b (in sec). Output % waveform has sampling rate sr (default 8000) and length 1 % samples (default: long enough to contain all blips). % 2006-05-02, 2006-09-30 dpwe@ee.columbia.edu if nargin < 2 sr = 8000; end if nargin < 3 1 = 0; end % 100ms pip @ 2khz tdur = 0.1; fblip = 2000; tt = (0:round(tdur*sr))'; x = tt.*exp(-tt/((tdur*sr)/10)).*cos(2*pi*tt/sr*fblip)/200; lx = length(x); bsamp = round(b*sr); % remove beats that would run off end if 1 > 0 bsamp = bsamp(bsamp < (l-lx)); else l = max(bsamp)+lx; end d = zeros(l,l); for bb = bsamp d(bb+[1:lx]) = d(bb+[1:lx]) + x;</pre> ``` #### mp3read.m ``` function [Y,FS,NBITS,OPTS] = mp3read(FILE,N,MONO,DOWNSAMP,DELAY) is MP3READ Read MP3 audio file via use of external binaries. Is Y = MP3READ (FILE) reads an mp3-encoded audio file into the vector Y just like wavread reads a wav-encoded file (one channel is per column). Extension ".mp3" is added if FILE has none. Is Also accepts other formats of wavread, such as Y = MP3READ(FILE,N) to read just the first N sample frames (N is calar), or the frames from N(1) to N(2) if N is a two-element vector. Is Y = MP3READ(FILE,FMT) or Y = mp3read(FILE,N,FMT) is with FMT as 'native' returns intl6 samples instead of doubles; If FMT can be 'double' for default behavior (to exactly mirror the is syntax of wavread). % [Y,FS,NBITS,OPTS] = MP3READ(FILE...) returns extra information: % FS is the sampling rate, NBITS is the bit depth (always 16), % OPTS.fmt is a format info string; OPTS has multiple other % fields, see WAVREAD. {\tt SIZ} = {\tt MP3READ}({\tt FILE}, '{\tt size'}) returns the size of the audio data contained in the file in place of the actual audio data, returning the 2-element vector {\tt SIZ}=[{\tt samples}\ {\tt channels}]. is [Y...] = MP3READ (FILE, N, MONO, DOWNSAMP, DELAY) extends the WAVREAD syntax to allow access to special features of the impg123 angine: MONO = 1 forces output to be mono (by impg123 angine: MONO = 1 forces output to be mono (by impg123 accessed and to the mono (by impg123 accessed and the property of the property of a factor of 2 or 4 (thus FS returns as 22050 or 11025 is respectively for a 44 kHz mp3 file); if to accommodate a bug in mpg123-0.59, DELAY controls how many impg123-0.59, DELAY controls how many impg123 accessed and the start of the file; the impgread of impg125 accessed and the property of prop = MP3READ(FILE, N, MONO, DOWNSAMP, DELAY) extends the [Y...] = MP3READ(URL...) uses the built-in network functionality of mpg123 to read an MP3 file across the network. URL must be of the form 'http://...' or 'ftp://...' 'size' and OPTS are not available in this mode. To read an mp3 file as doubles at its original width and sampling rate: [Y,FS] = mp3read('piano.mp3'); To read the first 1 second of the same file, downsampled by a factor of 4, cast to mono, using the default filename extension: % [Y,FS4] = mp3read('piano', FS/4, 1, 4); Note: Because the mp3 format encodes samples in blocks of 26 ms (at 44 kHz), and because of the "warm up" period of the encoder, the file length may not be exactly what you expect, depending on your version of mpg123 (recent versions fix warmup). requires external binaries mpg123 and mp3info; you % can find binaries for several platforms at: % http://labrosa.ee.columbia.edu/matlab/mp3read.html % See also mp3write, wavread. % $Header: /Users/dpwe/matlab/columbiafns/RCS/mp3read.m,v 1.6 2009/12/08 16:35:23 dpwe Exp dpwe $ % 2003-07-20 dpwe@ee.columbia.edu This version calls mpgl23. % 2004-08-31 Fixed to read whole files correctly 2 2004-09-08 Uses mpsinfo to get info about mp3 files too % 2004-09-18 Reports all mp3info fields in OPTS.fmt; handles MFGZLSF sizes % + added MONO, DONNSAMP flagas, changed default behavior. % 2005-09-28 Fixed bug reading full-rate stereo as lch (thx bjoerns@vjk.dk) % 2006-09-17 Chop off initial 2257 sample delay (for 44.1 kHz mp3) % so read-write loop doesn't get progressively delayed. % You can suppress this with a 5th argument of 0. % 2007-02-04 Added support for FMT argument to match wavread % Added automatic selection of binary etc. to allow it % to work cross-platform without editing prior to % submitting to Matlab File Exchange % 2007-07-23 Tweaks to 'size' mode so it exactly agrees with read data. % 2009-03-15 Added fixes so 'http://...' file URLs will work. % 2009-03-26 Added filename length check to http: test (thx fabricio guzman) % 2003-07-20 dpwe@ee.columbia.edu This version calls mpg123. % find our baseline directory path = fileparts(which('mp3read')); % %%%% Directory for temporary file (if needed) % % Try to read from environment, or use /tmp if it exists, or use CWD tmpdir = getenv('TMPDIR'); if isempty(tmpdir) || exist(tmpdir,'file')==0 tmpdir = '/tmp'; if exist(tmpdir,'file')==0 tmpdir = "; end % ensure it exists %if length(tmpdir) > 0 && exist(tmpdir,'file')==0 % mkdir(tmpdir); %end ``` ``` ****** Location of the binaries - attempt to choose automatically ****** (or edit to be hard-coded for your installation) ext = lower(computer); if ispc ext = 'exe'; rmcmd = 'del'; end * mpq123 ^ end % mpg123-0.59 inserts silence at the start of decoded files, which % we compensate. However, this is fixed in mpg123-1.9.0, so % make this flag 1 only if you have mpg123-0.5.9 MPG123059 = 0; mpg123 = fullfile(path,['mpg123.',ext]); mp3info = fullfile(path,['mpg13.',ext]); %%%% Check for network mode if length(FILE) > 6 && (strcmp(lower(FILE(1:7)),'http://') == 1 ... || strcmp(lower(FILE(1:6)),'ftp://')) % mp3info not available over network OVERNET = 1; else OVERNET = 0; end %%%% Process input arguments if nargin < 2 N = 0; % Check for FMT spec (per wavread) FMT = 'double'; if ischar(N) FMT = lower(N); N = 0; end \label{eq:specified} \begin{array}{ll} \text{ if length}\,(N) \; == \; 1 \\ \$ \; \text{Specified} \; N \; \text{was upper limit} \\ N \; = \; [1 \; N] \; ; \\ \text{end} \\ \text{if} \; r \; \cdot \end{array} if nargin < 3 forcemono = 0; else % Check for 3rd arg as FMT if ischar(MONO) FMT = lower(MONO); MONO = 0; end forcemono = (MONO = 0); end if nargin < 4 else downsamp = DOWNSAMP; end if downsamp = 1 && downsamp = 2 && downsamp = 4 error('DOWNSAMP can only be 1, 2, or 4'); end % process DELAY option (nargin 5) after we've read the SR if strcmp(FMT,'native') == 0 && strcmp(FMT,'double') == 0 && ... strcmp(FMT,'size') == 0 error(['FMT must be "native" or "double" (or "size"), not "',FMT,""]); end %%%%% Constants NBITS=16; %%%% add extension if none (like wavread) path,file,ext = fileparts(FILE); if isempty(ext) FILE = [FILE, '.mp3']; end if OVERNET %%%%% Probe file to find format, size, etc. using "mp3info" utility cmd = ['"',mp3info, '" -r m -p "%0 %u %b %r %v %C %e %E %L %0 %o %p" "', FILE,'"']; % Q = samprate, u = #frames, b = #badframes (needed to get right answer from %u) % r = bitrate, v = mpeg version (1/2/2.5) % C = Copyright, e = emph, E = CRC, L = layer, O = orig, o = mono, p = pad w = mysystem(cmd); % Break into numerical and ascii parts by finding the delimiter we put in starpos = findstr(w,'*'); nums = str2num(w(1:starpos - 2))); strs = tokenize(w((starpos+2):end)); SR = nums(1); SR = nums(1); nframes = nums(2); nchans = 2 - strcmp(strs6, 'mono'); layer = length(strs4); bitrate = nums(4)*1000; mpgv = nums(5); % Figure samples per frame, after % http://board.mp3-tech.org/view.php3?bn=agora_mp3techorg&key=1019510889 if layer == 1 smpspfrm = 384; ``` ``` elseif SR < 32000 && layer ==3 smpspfrm = 576; if mpgv ==1 error('SR < 32000 but mpeg version = 1'); end else smpspfrm = 1152; end end OPTS.fmt.mpgBitrate = bitrate; OPTS.fmt.mpgVersion = mpgv; % fields from wavread's OPTS OPTS.fmt.nAvgBytesPerSec = bitrate/8; OPTS.fmt.nAvgBytesPerSec = bitrate/8; OPTS.fmt.nSamplesPerSec = SR; OPTS.fmt.nChannels = nchans; OPTS.fmt.nBlockAlign = smpspfrm/SR*bitrate/8; OPTS.fmt.nBlockAlign = smpspfrm/SR*bitrate/8; OPTS.fmt.mpgtRyrames = nframes; OPTS.fmt.mpgCopyright = strs1; OPTS.fmt.mpgCapyright = strs2; OPTS.fmt.mpgCapyright = strs2; OPTS.fmt.mpgCapyright = strs5; OPTS.fmt.mpgCapyright = strs5; OPTS.fmt.mpgCapyright = strs5; OPTS.fmt.mpgCapyright = strs6; OPTS.fmt.mpgCapyright = strs6; OPTS.fmt.mpgCapyright = strs6; OPTS.fmt.mpgCapyright = strs6; OPTS.fmt.mpgCapyright = strs6; OPTS.fmt.mpgCapyright = strs6; OPTS.fmt.mpgSampsPerFrame = smpspfrm; else else % OVERNET mode % OVERNET mode OPTS = []; % guesses smpspfrm = 1152; SR = 44100; nframes = 0; if SR == 16000 && downsamp == 4 error('mpg123 will not downsample 16 kHz files by 4 (only 2)'); % process or set delay if nargin < 5 if MPG123059 mpg123delay44kHz = 2257; % empirical delay of lame/mpg123 loop mpg123delay16kHz = 1105; % empirical delay of lame/mpg123 loop for 16 kHz sampling if SR == 16000 rawdelay = mpg123delay16kHz; rawdelay = mpg123delay16kHz; else rawdelay = mpg123delay44kHz; % until we know better end delay = round(rawdelay/downsamp); eise % seems like predelay is fixed in mpg123-1.9.0 delay = 0; end else delay = DELAY; end if downsamp == 1 downsampstr = "; acomisampstr , else downsampstr = [' -',num2str(downsamp)]; end FS = SR/downsamp; if forcemono == 1 nchans = 1; chansstr = ' -m'; else chansstr = "; end % Size-reading version if strcmp(FMT,'size') == 1 Y = [floor(smpspfrm*nframes/downsamp)-delay, nchans]; else skipx = 0; skipblks = 0; skipstr = "; sttfrm = N(1)-1; % chop off transcoding delay? %stffm = stffm + delay; % empirically measured % no, we want to *decode* those samples, then drop them % so delay gets added to skipx instead if sttfrm > 0 skipblks = floor(sttfrm*downsamp/smpspfrm); skipx = sttfrm - (skipblks*smpspfrm/downsam; skipstr = [' -k ', num2str(skipblks)]; skipx = skipx + delay; lenstr = "; endfrm = -1; ``` ``` decblk = 0; if length(N) > 1 endfrm = N(2); if endfrm > sttfrm decblk = ceil((endfrm+delay)*downsamp/smpspfrm) - skipblks + 10; % we read 10 extra blks (+10) to cover the case where up to 10 bad % blocks are included in the part we are trying to read (it happened) lenstr = [' -n ', num2str(decblk)]; % This generates a spurious "Warn: requested..." if reading right % to the last sample by index (or bad blks), but no matter. end % Run the decode cmd=['"',mpg123,'"', downsampstr, chansstr, skipstr, lenstr, ... ' -q -w "', tmpfile,'" "',FILE,'"']; %w = end mysystem(cmd); % Load the data Y = wavread(tmpfile); if decblk > 0 && length(Y) < decblk*smpspfrm/downsamp % This will happen if the selected block range includes >1 bad block disp(['Warn: requested', num2str(decblk*smpspfrm/downsamp),' frames, returned',num2str(length(Y))]); % Delete tmp file mysystem([rmcmd,' "', tmpfile,'"']); \begin{tabular}{ll} \$ & debug \\ \$ & disp(['sttfrm=',num2str(sttfrm),' endfrm=',num2str(endfrm),' skipx=',num2str(skipx),' delay=',num2str(delay),' len=',num2str(length(Y))]); \\ \end{tabular} % Select the desired part if skipx+endfrm-sttfrm > length(Y) endfrm = length(Y)+sttfrm-skipx; end if endfrm > sttfrm Y = Y(skipx+(1:(endfrm-sttfrm)),:); elseif skipx > 0 Y = Y((skipx+1):end,:); % Convert to int if format = 'native' if strcmp(FMT,'native') Y = intl6((215)*Y); end end error(['unable to execute ',cmd,' (',w,')']); error(['unable to execute ',cmd,' (',w,end end % Keep just final line w = w((1+max([0,findstr(w,10)])):end); % Debug %disp([cmd,' -> ','*',w,'*']); $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$ if nargin < 2; t = ' '; end a = []; p = 1; n = 1; 1 = length(s); nss = findstr([s(p:end),t],t); for ns = nss % Skip initial spaces (separators) if ns == p p = p+1; else if p <= 1</pre> else if p <= 1 an = s(p:(ns-1)); n = n+1; p = ns+1; end end end ``` #### mymkdir.m ``` function r = mymkdir(dir) \ r = mymkdir(dir) \ Ensure that dir exists by creating all its parents as needed. ``` #### octs2hz.m ``` function hz = octs2hz(octs,A440) % hz = octs2hz(octs,A440) % Convert a real-number octave % into a frequency in Hzfrequency in Hz into a real number counting % the octaves above A0. So hz2octs(440) = 4.0. % Optional A440 specifies the Hz to be treated as middle A (default 440). % 2006-06-29 dpwe@ee.columbia.edu for fft2chromamx if nargin < 2; A440 = 440; end % A4 = A440 = 440 Hz, so A0 = 440/16 Hz hz = (A440/16).*(2.ôcts);</pre> ``` #### tempo.m ``` function [t,xcr,D,onsetenv,sgsrate] = tempo(d,sr,tmean,tsd,onsetenv,debug) % [t,xcr,D,onsetenv,sgsrate] = tempo(d,sr,tmean,tsd,onsetenv,debug) % Estimate the overall tempo of a track for the MIREX McKinney % contest. % d is the input audio at sampling rate sr. tmean is the mode % for BPM weighting (in bpm) and tsd is its spread (in octaves). % onsetenv is an already-calculated onset envelope (so d is % ignored). debug causes a debugging plot. % Output t(1) is the lower BPM estimate, t(2) is the faster, % t(3) is the relative weight for t(1) compared to t(2). % xcr is the windowed autocorrelation from which the BPM peaks were picked. % D is the mel-freq spectrogram % onsetenv is the "onset strength waveform", used for beat tracking % sgsrate is the sampling rate of onsetenv and D. % % 2006-08-25 dpwe@ee.columbia.edu % uses: localmax, fftZmelmx % Copyright (c) 2006 Columbia University. % % This file is part of LabROSA-coversongID % % LabROSA-coversongID is free software; you can redistribute it and/or modify % ti under the terms of the GNU General Public License version 2 as % published by the Free Software Foundation. % LabROSA-coversongID is distributed in the hope that it will be useful, but % WITHOUT ANY WARRANTY; without even the implied warranty of % MRECHANTABLILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU % General Public License for more details. % You should have received a copy of the GNU General Public License % along with LabROSA-coversongID; if not, write to the Free Software % Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA % 0210-1301 USA % See the file "COPYING" for the text of the license. if nargin < 4; tsd = 3.0; end if nargin < 6; debug = 0; end sro = 8000; % specgram: 256 bin @ 8RHz = 32 ms / 4 ms hop swin = 256; shop = 32; % mel channels nmel = 40; % sample rate for specgram frames (granularity for rest of processing) sgsrate = sro/shop; % autoco out to 4 s acmax = round(4*sgsrate); D = 0; if length(onsetenv) = 0 % no onsetenv provided - have to calculate it % resample ``` ``` D = specgram(d, swin, sr, swin, swin-shop); % Construct db-magnitude-mel-spectrogram mlmx = fft2melmx(swin,sr,nmel); D = 20*log10(max(le-10,mlmx(:,1:(swin/2+1))*abs(D))); % Only look at the top 80 dB D = max(D, max(max(D))-80); % The raw onset decision waveform mm = (mean(max(0,diff(D')'))); eelen = length(mm); % dc-removed mm onsetenv = filter([1 -1], [1 -.99],mm); end % of onsetenv calc block % Find rough global period % Only use the 1st 90 sec to estimate global pd (avoid glitches?) maxdur = 90; % sec maxcol = min(round(maxdur*sgsrate),length(onsetenv)); xcr = xcorr(onsetenv(1:maxcol),onsetenv(1:maxcol),acmax); % find local max in the global ac rawxcr = xcr(acmax+1+[0:acmax]); xpks = localmax(xcr); % will not include any peaks in first down slope (before goes below % zero for the first time) xpks(l:min(find(xcr<0))) = 0; % largest local max away from zero maxpk = max(xcr(xpks));</pre> % ?? then period is shortest period with a peak that approaches the max %maxpkthr = 0.4; %startpd = -1 + min(find( (xpks.*xcr) > maxpkthr*maxpk ) ); %startpd = -1 + (find( (xpks.*xcr) > maxpkthr*maxpk ) ); % no, just largest peak after windowing startpd = -1 + find((xpks.*xcr) == max(xpks.*xcr)); % ??Choose acceptable peak closest to 120 bpm %[vv,spix] = min(abs(60./(startpd/sgsrate) - 120)); %startpd = startpd(spix); % No, just choose shortest acceptable peak startpd = startpd(1); t = 60/(startpd/sgsrate); % Choose best peak out of .33 .5 2 3 x this period candpds = round([.33 .5 2 3]*startpd); candpds = candpds(candpds < acmax);</pre> [vv,xx] = max(xcr(1+candpds)); startpd2 = candpds(xx); vvm = xcr(1+startpd); pratio = vvm/(vvm+vv); t = [60/(startpd/sgsrate) 60/(startpd2/sgsrate) pratio]; \begin{tabular}{ll} \$ \ ensure \ results \ are \ lowest-first \\ if \ t(2) < t(1) \\ t([1\ 2]) = t([2\ 1]); \\ t(3) = 1-t(3); \\ \end{tabular} end if debug > 0 subplot (414) subplot(414) plot([0:acmax],xcr,'-b', ... 0:acmax,xcrwin*maxpk,'-r', ... startpd startpd, [min(xcr) max(xcr)], '-g', ... startpd2 startpd2, [min(xcr) max(xcr)], '-c'); grid; end % Read in all the tempo settings % for i = 1:20; f = fopen(['mirex-beattrack/train/train',num2str(i),'-tempo.txt']); r(i,:) = fscanf(f, ' ``` #### testlist.m ``` function [R,S,T] = testlist(queryflist,testflist,pwr,norm,metric,xcr,verb); % [R,S,T] = testlist(queryflist,testflist,pwr,norm,metric,xcr,verb); % Takes a list of query files and compares each one to all % of a list of test files. % R returns a matrix of score values, each row is a query, each % column is one of the test elements. % S is a local normalization index; T is the best alignment time skew. % pwr is power to raise chroma vectors to (dflt 1). % norm is the normalization mode for the xcorr (0 = none, 1 = by shorter) % metric is the metric used (1 = peak xcorr, 2 = peak filtered xcorr) % xcr = 1 means fast cross-correlation (default 0) % verb > 0 means provide progress update % 2006-07-27 dpwe@ee.columbia.edu if nargin < 3; pwr = 1; end if nargin < 4; norm = 1; end if nargin < 5; metric = 1; end if nargin < 6; xcr = 0; end if nargin < 7; verb = 0; end</pre> [tsongs,ntsongs] = listfileread(testflist); qsongs,nqsongs = listfileread(queryflist); % Now run through the queries for q = 1:nqsongs \label{eq:continuous} \mbox{if (verb > 0)} \\ \mbox{disp([datestr(rem(now,l),'HH:MM:SS'), ' ', 'doing song ',num2str(q),' ', qline]);} \\ \mbox{} Q = load(qline); Q.F = chromnorm(chromapwr(Q.F,pwr)); maxlag = 800; for i = 1:ntsongs % if (verb > 0) % disp(['..versus ', tsongsi]); P = load(tsongsi); P.F = chromnorm(chromapwr(P.F,pwr)); if xcr == 0 r = chromxcorr2(Q.F, P.F, norm); % fast version of xcor r = chromxcorr2fast(Q.F, P.F, norm, maxlag); end mmr = max(max(r)); bestchrom = find(max(r') == mmr); besttime = find(max(r) == mmr); if metric == 1 If metric = 1 R(q,i) = mmr; S(q,i) = mean(mean(r(:,max(besttime-100,1):min(besttime+100,size(r,2))))); elseif metric == 2 \ \mbox{$\S$} Look for rapid variation - do HPF along time of best chrom fxc = filter([1 -1], [1 -.9], r(bestchrom,:)-mean(r(bestchrom,:))); \ \mbox{$\S$} chop off first bit - onest transient for \mbox{$\S$} start-in-the-middle fxc(1:50) = min(fxc); R(q,i) = max(fxc); if (xcr == 0) refpt = length(Q.F); else else refpt = maxlag; end besttime = find(fxc == max(fxc))-refpt; T(q,i) = besttime; disp([datestr(rem(now,1),'HH:MM:SS'), ' ..versus ', tsongsi,' ',num2str(max(fxc)),' @ ',num2str(besttime)]) S\left(\mathbf{q},\mathbf{i}\right) = \operatorname{sqrt}\left(\operatorname{mean}\left(\operatorname{fxc}\left(\operatorname{max}\left(\operatorname{besttime+refpt-100},1\right): \operatorname{min}\left(\operatorname{besttime+refpt+100},\operatorname{length}\left(\operatorname{fxc}\right)\right)\right).\hat{2}\right)\right); end if (0) % not wanted for submission version - self included in lists % scoring - find largest entry in each row (query) tt = 1:length(xx); aa = (xx == tt); ``` ``` disp(['Simple max: acc = ',num2str(mean(aa),3),' ',num2str(aa)]); vv,xx = max((R./S)'); aa = (xx == tt); disp(['Ratio max: acc = ',num2str(mean(aa),3),' ',num2str(aa)]); end ``` #### test.m ``` function [] = test (B,d6,sr6) figure(); hold for i = 1:length(B) counter = floor(4*rand(1)); if (counter ==0) 'PRESS A' elseif (counter == 1) 'PRESS B' elseif (counter == 2) 'PRESS C' elseif (counter == 3) 'PRESS D' end plot([mod(i,2)+i,mod(i+1,2)+i+1],[mod(i,2),mod(i+1,2)]); sound(d6((B(i)*sr6): ((B(i)+1)*sr6)),sr6) end ``` ### **PYTHON** source code ### toHexArray.py ``` #Encode a song into binary format from struct import * import sys #Usage notice if len(sys.argv)==1: print """usage: python encode.py file1 file2 file1 => name of the input file file1 => name of the output file """ exit() #Arguments acquiring filein = sys.argv[1] fileout = sys.argv[2] #open the file that contains the notes f = open(filein) lines = f.readlines() f.close() for i in range(len(lines)): lines[i] = hex(int(lines[i]))+str("") num = len(lines) #open the binary file for write g = open(fileout, "w") g.write(",".join(lines)) #close binary stream g.close() ``` ### encode.py ``` \# Encode a song into binary format from struct import \star import sys #Usage notice if len(sys.argv)==1: print """usage: python encode.py file1 file2 id file1 => name of the input file file2 => name of the output binary file id => id of the song exit() #Arguments acquiring filein = sys.argv[1] fileout = sys.argv[2] id_song = sys.argv[3] #Resolution computing NBYTE = 2 MAX_LENGTH = 60.0*4 #4 minutes res = int( (2**(NBYTE*8)) / MAX_LENGTH ) #open the file that contains the notes f = open(filein) lines = f.readlines() f.close() #get the number of notes num = len(lines) #open the binary file for write g = open(fileout, "w") #write the id of the song, the number of notes # c = character(1 byte), h = short(2 bytes) id_song = int(id_song) g.write(pack("B", d_song)) g.write(pack("h", num)) #Iterating through the beats for i in range(len(lines)): color = int(lines[i].split()[0]) time = float(lines[i].split()[1]) val = time*res #timestamp value g.write(pack("Bh",color,val)) #close binary stream g.close() ``` ### randomize.py ``` \# \mbox{Insert} random notes in front of every line import sys import random #Acquire the notes f = open(sys.argv[1]) lines = f.readlines() f.close() #Add the random notes for i in range(len(lines)): lines[i]=str(random.randrange(0,4))+" "+lines[i] #Write the resulting list f = open(sys.argv[1],"w") f.write("".join(lines)) f.close() ``` ### shortest\_time\_dist.py ``` #Compute the shortest time length #between two consecutive notes in #a song # import sys import random #Acquire the notes f = open(sys.argv[1]) lines = f.readlines() f.close() ``` ``` dist = 87439873298473298 #a lot for i in range(len(lines)-1): cur = float(lines[i].split()[l].rstrip()) #current note nex = float(lines[i+1].split()[l].rstrip()) #next note if nex - cur < dist: dist = nex - cur print "shortest distance "+str(dist)</pre> ``` ### C source code ### Hello World.c ``` /* * "Hello World" example. * This example prints 'Hello from Nios II' to the STDOUT stream. It runs on * the Nios II 'standard', 'full_featured', 'fast', and 'low_cost' example * designs. It runs with or without the MicroC/OS-II RTOS and requires a STDOUT * device in your system's hardware. The memory footprint of this hosted application is 69 kbytes by default * using the standard reference design. * For a reduced footprint version of this template, and an explanation of how to reduce the memory footprint for a given application, see the "small_hello_world" template. */ #include <system.h> #include <stdio.h> #include <1o.h> #include <1o.h> #include <sys/alt_irq.h> #include <alt_types.h> #include <time.h> #include <unistd.h> #include <unistd.h> #ifdef _unix__ # include <unistd.h> #ellif defined _WIN32 # include <unistd.h> # i volatile int val = 0; volatile int key = 0; // for beats volatile int beat_counter = 0; \ensuremath{//} I set the displayed key each time val is incremented. static void irqhandler (void * context, alt_u32 id) { val ++; key = 1; IOWR_8DIRECT(INPUTCONTROLLER_INST_BASE, 0, 0); // reset request static void irqhandler2 (void * context, alt_u32 id) key = 2; IOWR_8DIRECT(INPUTCONTROLLER2_INST_BASE, 0, 0); // reset request static void irqhandler3 (void * context, alt_u32 id) { val ++; key = 3; IOWR_8DIRECT(INPUTCONTROLLER3_INST_BASE, 0, 0); // reset request static void irghandler4 (void * context, alt_u32 id) key = 4; IOWR_8DIRECT(INPUTCONTROLLER4_INST_BASE, 0, 0); // reset request static void irghandler5 (void * context, alt_u32 id) { val ++; key = 5; IOWR_8DIRECT(INPUTCONTROLLERS_INST_BASE, 0, 0); // reset request static void irghandler6 (void * context, alt u32 id) lbeat_counter = beat_counter+2;//2 coups de clock IOWR_8DIRECT(INPUTCONTROLLER6_INST_BASE, 0, 0); // reset request ``` ``` typedef struct note{ int color ; int timestamp; }note: 0x02fa, 0x0321, 0x0348, 0x0370, 0x039a, 0x03c1, 0x03eb, 0x0414, 0x043a, 0x0467, 0x048a, 0x04b3, 0x04da, 0x0503, 0x052b, 0x0553, 0x055a, 0x055a, 0x055a, 0x055a, 0x055a, 0x056a, 0x065a, 0x056a, 0x066a, 0x066a, 0x066a, 0x0709, 0x0731, 0x0750, 0x0731, 0x0750, 0x056a, 0x066a, 0x066a, 0x066a, 0x0931, 0x095a, 0x0951, 0x09ac, 0x09a1, 0x09ac, 0x09a1, 0x09ac, 0x09a1, 0x09ac, 0x09a1, 0x09ac, 0x09a1, 0x09ac, 0x09a1, 0x09ac, 0x06ac, 0x0cce, 0x06ca, 0x0cce, 0x06ca, 0x0cce, 0x06ca, 0x0cce, 0x06ca, 0x0cce, 0x06ca, 0x0cce, 0x06ca, 0x0dce, 0x0dce, 0x0dce, 0x0dce, 0x0dce, 0x0dce, 0x0dce, 0x0cce, 0x0ece, 0x0ece static void input_isr ( void* context, alt_u32 id) . zalz++: IOWR_16DIRECT(INPUTCONTROLLER_INST_BASE, 0,0); return; int main() IOWR_8DIRECT(INPUTCONTROLLER_INST_BASE, 0, 0); IOWR_8DIRECT(INPUTCONTROLLER2_INST_BASE, 0, 0); IOWR_8DIRECT(INPUTCONTROLLER3_INST_BASE, 0, 0); IOWR_8DIRECT(INPUTCONTROLLER4_INST_BASE, 0, 0); IOWR_8DIRECT(INPUTCONTROLLER4_INST_BASE, 0, 0); IOWR 8DIRECT(INPUTCONTROLLER6 INST BASE, 0, 0); printf("main() started "); alt_irg_register( INPUTCONTROLLER_INST_IRQ, NULL, (void*)irqhandler ); // register the irq alt_irq_register( INPUTCONTROLLER2_INST_IRQ, NULL,(void*)irqhandler2 ); // register the irq alt irg register ( INPUTCONTROLLER3 INST IRQ, NULL, (void*) irghandler3 ); // register the irg alt_irq_register( INPUTCONTROLLER4_INST_IRQ, NULL, (void*)irqhandler4 ); // register the irq alt_irq_register( INPUTCONTROLLER5_INST_IRQ, NULL,(void*)irqhandler5 ); // register the irq alt_irq_register( INPUTCONTROLLER6_INST_IRQ, NULL,(void*)irqhandler6 ); // register the irq // value from the buffer may be displayed, no worries printf("Hello from Nios II!"); int counter = 0; int flag = 0; int val_buffer = val; int key_buffer = floor(rand(5)); int score = 0: while (counter<540) { if (flag!=1) { if (val>val_buffer) { if (key==key_buffer) { flag = 1; score = score+1; } score = score+1; printf("SUCCESS: SCORE %d", score);}} // rajouter booleen pour afficher succes qu'une seule fois if (beat counter>=(beats[counter]) *3) { if (flag == 0) { ``` volatile int valz = 0: ``` printf("FAIL: SCORE %d",score);) flag = 0; val_buffer = val; key_buffer = floor(1+rand()%5); printf("PRESS %d",key_buffer); counter=counter+1; } } printf("FINISHED!"); while(counter<541){ if(counter>0){ set_timer(0, beats[counter]*40 - beats[counter-1]*40 );} else{ set_timer(0, beats[counter]*40;} } launch_timer(); while(1){ if(timer_expired() ==1) break; } if (flag == 0){ printf("FAIL");} printf("FAIL");} printf("[%d] %d ",counter, beats[counter]*40 ); counter=counter+1; } return 0; ``` ### **VHDL** source code #### AWESOME\_GUITAR.qpf ``` # Copyright (C) 1991-2007 Altera Corporation # Your use of Altera Corporation's design tools, logic functions # and other software and tools, and its AMPP partner logic # functions, and any output files from any of the foregoing # (including device programming or simulation files), and any # associated documentation or information are expressly subject # to the terms and conditions of the Altera Program License # Subscription Agreement, Altera MegaCore Function License # Agreement, or other applicable license agreement, including, # without limitation, that your use is for the sole purpose of # programming logic devices manufactured by Altera and sold by # Altera or its authorized distributors. Please refer to the # applicable agreement for further details. QUARTUS_VERSION = "7.2" DATE = "15:48:30 April 05, 2012" # Revisions PROJECT_REVISION = "AWESOME_GUITAR_TOP" ``` ### AWESOME\_GUITAR.qws ``` [ProjectWorkspace] ptn_Childl=Frames [ProjectWorkspace.Frames] ptn_Childl=ChildFrames [ProjectWorkspace.Frames.ChildFrames] ptn_Childl=Document-0 ptn_Childl=Document-1 ptn_Child3=Document-2 ptn_Child4=Document-3 [ProjectWorkspace.Frames.ChildFrames.Document-3] ptn_Child4=ViewFrame-0 [ProjectWorkspace.Frames.ChildFrames.Document-3.ViewFrame-0] DocPathName=guitar_top.vhd Documentt.SID=(cal85d57-a4c7-11d1-a098-0020affa43f2) IsChildFrameDetached=False IsActiveChildFrame=False ptn_Child1=StateMap [ProjectWorkspace.Frames.ChildFrames.Document-3.ViewFrame-0.StateMap] AFC_IN_REPORT=False ``` ### AWESOME\_GUITAR\_TOP.dpf ### AWESOME\_GUITAR\_TOP.jdi This file has not been modified from its original version. ### $AWESOME\_GUITAR\_TOP.qsf$ This file has not been modified from its original version. ### $AWE SOME\_GUITAR\_TOP.sof$ This file has not been modified from its original version. #### counter.vhd ``` library ieee; use ieee.std_logic_1164.all; use ieee.numeric_std.all; entity counter is port (( -Synchronous reset reset : in std_logic; clk: in std_logic; do: out unsigned(31 downto 0); di : in unsigned (31 downto 0) ); end counter; architecture arl of counter is signal value : unsigned(31 downto 0); begin process(clk) begin if(riesing_edge(clk)) then if( reset='1') then value <= di; else value <= value -1; end if; end if; end process; do <= value; -copy value to the output end arl; ``` ### cpu.ocp This file has not been modified from its original version. #### cpu.vhd This file has not been modified from its original version. #### cpu\_jtag\_debug\_module.vhd This file has not been modified from its original version. ### $cpu\_jtag\_debug\_module\_wrapper.vhd$ This file has not been modified from its original version. #### cpu\_ociram\_default\_contents.mif This file has not been modified from its original version. #### cpu\_rf\_ram.mif This file has not been modified from its original version. ### $cpu\_test\_bench.vhd$ This file has not been modified from its original version. ### DebounceCounter.vhd ``` -19 bit counter -19 bits since it needs to count to 20 ms -20 ms = 500 000 * tclock *2 - and 2**19 = 524 288 library ieee; use ieee.std_logic_l164.all; use ieee.numeric_std.all; entity DebounceCounter is port (-Synchronous reset reset : in std_logic; clk: in std_logic; clk: in std_logic; clk: in std_logic; do: out unsigned(18 downto 0) ); end DebounceCounter; architecture arl of DebounceCounter is signal value : unsigned(18 downto 0); begin process(clk) begin if(rising_edge(clk)) then if( reset='1') then value <= (others => '0'); else value <= value + 1; end if; end process; do <= value; -copy value to the output end arl; ``` #### debouncer.vhd ``` -Debouncer module -TODO include reset library ieee; use ieee.std_logic_l164.all; use ieee.numeric_std.all; entity debouncer is port ``` ``` clk : in std_logic; key_in : in std_logic; key_out : out std_logic; reset : in std_logic ); end debouncer; architecture arl of debouncer is type states is (ZERO, ZERO_TO_ONE, ONE, ONE_TO_ZERO); signal state, next_state: states; signal do: unsigned(18 downto 0); signal reset_counter: std_logic; -to reset the counter begin CO: entity work.DebounceCounter port map ( clk => clk, reset => reset_counter, do => do); -FSM Strandard next_state => state process(clk) begin if(rising_edge(clk)) then if( reset='1') then state <= ZERO; state <= ZERO; else state <= next_state; end if; end if; end process;</pre> -Computation of the next state process (state, key_in, do) process (state,key_in,do) begin next_state <= state; case state is -State ZERO -Signal generated: reset => 1, key_out => 0 when ZERO => reset_counter <= '1'; key_out <= '1'; if (key_in = '0') then</pre> then next_state <= ZERO_TO_ONE; end if; -State ZERO_TO_ONE -State ZERO_TO_ONE -Signal generated: reset => 0, key_out => 0 when ZERO_TO_ONE => reset_counter <= '0'; key_out <= '1'; if (do >= 500_000) then next_state <= ONE; end if; next_state <= ONE; end if; -State ONE -Signal generated: reset => 1, key_out => 1 when ONE => reset_counter <= '1'; key_out <= '0'; if (key_in = '1') then next_state <= ONE_TO_ZERO; end if:</pre> next_state <= unc_iO_ZERO; end if; -state ONE_TO_ZERO -signal generated: reset => 0, key_out => 1 when ONE_TO_ZERO => reset_counter <= '0'; key_out <- '0'; if (do >= 500_000) then next_state <= ZERO; end if; end case; end process; end arl; ``` ### de2\_i2c\_av\_config.v ``` /* * IZC bus control for initializing the audio and video chips on the DE2 board * * Adapted by Stephen A. Edwards, Columbia University, sedwards@cs.columbia.edu */ module de2_i2c_av_config( iCLK, iRST_N, I2C_SCLK, I2C_SDAT ); // From host ``` ``` input iCLK; input iRST_N; // I2C bus output I2C_SCLK; inout I2C_SDAT; // Internal Registers/Wires reg [15:0] mI2C_CLK_DIV; reg [23:0] mI2C_DATA; reg mI2C_CTRL_CLK; reg mI2C_GO; wire mI2C_END; wire mI2C_ACK; reg [15:0] LUT_DATA; reg [5:0] LUT_INDEX; reg [3:0] mSetup_ST; // Clock frequencies parameter CLK_Freq = 50000000; // 50 MHz parameter I2C_Freq = 20000; // 20 kHz parameter LUT_SIZE = 50; parameter LOT_SIZE = : // Audio Data Index parameter SET_LIN_R = 0; parameter SET_LIN_R = 1; parameter SET_HEAD_R = 3; parameter SET_HEAD_R = 3; parameter A_PATH_CTRL = 4; parameter D_PATH_CTRL = 5; parameter SET_FORMAT = 7; parameter SET_FORMAT = 7; parameter SET_FORMAT = 9; // Video Data Index parameter SET_VIDEO = 10; // I2C Control Clock always (posedge iCLK or negedge iRST_N) begin if (!iRST_N) begin mI2C_CTRL_CLK <= 0; mI2C_CLK_DIV <= 0; mIZC_CLK_DIV <= 0; end else begin if ( mIZC_CLK_DIV < (CLK_Freq/IZC_Freq) ) mIZC_CLK_DIV <= mIZC_CLK_DIV+1; else begin wegun mI2C_CLK_DIV <= 0; mI2C_CTRL_CLK <= mI2C_CTRL_CLK; end end end de2_i2c_controller u0 ( .CLOCK(mI2C_CTRL_CLK), // Controller Work Clock .I2C_SCLK(I2C_SCLK), // I2C CLOCK .I2C_SDAT(I2C_SDAT), // I2C DATA .I2C_DATA(mI2C_DATA), // DATA:[SLAVE_ADDR,SUB_ADDR,DATA] .GO(mI2C_GO), // GO transfor .ACK(mI2C_ACK), // ACK .RESET(iRST_N) ): // Configuration control always (posedge mI2C_CTRL_CLK or negedge iRST_N) begin if(!iRST_N) begin LUT_INDEX <= 0; mSetup_ST <= 0; mI2C_GO <= 0; end else begin</pre> begin if (LUT_INDEX<LUT_SIZE)</pre> IT (LUI_INDEX.LUI_SIZE) begin case(mSetup_ST) 0: begin if(LUI_INDEX<SET_VIDEO) mI2C_DATA <= 8'h34,LUI_DATA; mI2C_DATA <= 8'h40,LUT_DATA; mI2C_GO <= 1; mSetup_ST <= 1; mSetup_ST <= 1; end 1: begin if (mI2C_END) begin if (!mI2C_ACK) mSetup_ST <= 2; else else mSetup_ST <= 0; ``` ``` mI2C_GO <= 0; end end 2: begin LUT_INDEX <= LUT_INDEX+1; mSetup_ST <= 0; end end // Configuration data LUT always always begin case (LUT_INDEX) // Audio Config Data SET_LIN_L: LUT_DATA <= 16'h001A; SET_LIN_R: LUT_DATA <= 16'h001A; SET_LIN_R: LUT_DATA <= 16'h007A; SET_HEAD_L: LUT_DATA <= 16'h047B; SET_HEAD_L: LUT_DATA <= 16'h067B; A_PATH_CTRL: LUT_DATA <= 16'h067B; D_PATH_CTRL: LUT_DATA <= 16'h080B; D_PATH_CTRL: LUT_DATA <= 16'h080C; SET_FORMAT: LUT_DATA <= 16'h080C; SET_FORMAT: LUT_DATA <= 16'h1000; SET_FORMAT: LUT_DATA <= 16'h1001; SAMPLE_CTRL: LUT_DATA <= 16'h1001; SAMPLE_CTRL: LUT_DATA <= 16'h1201; // Video Config Data SET_VIDEO+0: LUT_DATA <= 16'h1301; SET_VIDEO+0: LUT_DATA <= 16'h1341; SET_VIDEO+1: LUT_DATA <= 16'h304; SET_VIDEO+1: LUT_DATA <= 16'h304; SET_VIDEO+3: LUT_DATA <= 16'h304; SET_VIDEO+3: LUT_DATA <= 16'h308; SET_VIDEO+5: LUT_DATA <= 16'h6480; SET_VIDEO+5: LUT_DATA <= 16'h6480; SET_VIDEO+5: LUT_DATA <= 16'h5004; SET_VIDEO+6: LUT_DATA <= 16'h5004; SET_VIDEO+6: LUT_DATA <= 16'h5008; SET_VIDEO+10: LUT_DATA <= 16'h5218; SET_VIDEO+11: LUT_DATA <= 16'h5218; SET_VIDEO+11: LUT_DATA <= 16'h5218; SET_VIDEO+10: LUT_DATA <= 16'h520; SET_VIDEO+11: LUT_DATA <= 16'h520; SET_VIDEO+12: LUT_DATA <= 16'h3480; SET_VIDEO+13: LUT_DATA <= 16'h3480; SET_VIDEO+14: LUT_DATA <= 16'h348; SET_VIDEO+15: LUT_DATA <= 16'h348; SET_VIDEO+15: LUT_DATA <= 16'h348; SET_VIDEO+16: LUT_DATA <= 16'h348; SET_VIDEO+19: 16'h360; SET_VIDEO+20: LUT_DATA <= 16'h360; SET_VIDEO+21: LUT_DATA <= 16'h3780; SET_VIDEO+22: LUT_DATA <= 16'h3780; SET_VIDEO+23: LUT_DATA <= 16'h350; SET_VIDEO+24: LUT_DATA <= 16'h360; SET_VIDEO+25: LUT_DATA <= 16'h360; SET_VIDEO+26: LUT_DATA <= 16'h360; SET_VIDEO+31: LUT_DATA <= 16'h300; SET_VIDEO+31: LUT_DATA <= 16'h300; SET_VIDEO+31: LUT_DATA <= 16'h300; SET_VIDEO+31: LUT_DATA <= 16'h300; SET_VIDEO+31: LUT_DATA <= 16'h300; SET_VIDEO+33: LUT_DATA <= 16'h300; SET_VIDEO+33: LUT_DATA <= 16'h26c; SET_VIDEO+39: LUT_DAT ``` endmodule # de2\_i2c\_controller.v ``` // // Copyright (c) 2005 by Terasic Technologies Inc. // // Permission: // // Permission: // // Terasic grants permission to use and modify this code for use // in synthesis for all Terasic Development Boards and Altrea Development // Kits made by Terasic. Other use of this code, including the selling, // duplication, or modification of any portion is strictly prohibited. // // Disclaimer: // // This VHDL or Verilog source code is intended as a design reference // which illustrates how these types of functions can be implemented. // It is the user's responsibility to verify their design for // consistency and functionality through the use of formal // verification methods. Terasic provides no warranty regarding the use // or functionality of this code. ``` ``` // // Terasic Technologies Inc // 356 Fu-Shin E. Rd Sec. 1. JhuBei City, // HsinChu County, Taiwan // 302 // Major Functions:i2c controller module de2_12c_controller ( CLOCK, 12C_SCLK, // IZC CLOCK 12C_SCLK, // IZC CLOCK 12C_SDATA, // DATA:[SLAVE_ADDR,SUB_ADDR,DATA] GO, // GO transfor END, // END transfor W_R, // W_R ACK, // ACK RESET, // TEST SD_COUNTER, SDO ); ); input CLOCK; input [23:0] I2C_DATA; input GO; input RESET; input W_R; inout I2C_SDAT; output I2C_SCLK; output END; output ACK; // TEST output [5:0] SD_COUNTER; output SDO; reg SDO; reg SCLK; reg END; reg [23:0] SD; reg [5:0] SD_COUNTER; wire I2C_SCLK = SCLK | (((SD_COUNTER >= 4) & (SD_COUNTER <= 30))? CLOCK : 0); wire I2C_SDAT = SDO ? 1'bz : 0; reg ACK1, ACK2, ACK3; wire ACK = ACK1 | ACK2 | ACK3; //-I2C COUNTER always (negedge RESET or posedge CLOCK) begin if (!RESET) SD_COUNTER = 6'blllll1; else begin if (GO == 0) SD_COUNTER = 0; else else if (SD_COUNTER < 6'bll1111) SD_COUNTER = SD_COUNTER + 1; always @(negedge RESET or posedge CLOCK ) begin if (!RESET) begin SCLK = 1; SDO = 1; ACK1 = 0; ACK2 = 0; ACK3 = 0; END = 1; end end else case (SD_COUNTER) 6'd0 : begin ACK1 = 0; ACK2 = 0; ACK3 = 0; END = 0; SDO = 1; SCLK = 1; end // Start 6'd1 : begin SD = I2C_DATA; SDO = 0; end 6'd2 : SCLK = 0; ``` ``` // Slave Address 6'd3: SDO = SD[23]; 6'd4: SDO = SD[22]; 6'd5: SDO = SD[21]; 6'd6: SDO = SD[21]; 6'd6: SDO = SD[21]; 6'd7: SDO = SD[19]; 6'd8: SDO = SD[19]; 6'd8: SDO = SD[18]; 6'd9: SDO = SD[17]; 6'd10: SDO = SD[16]; 6'd11: SDO = 1'b1; //ACK // Sub-address 6'd12: begin SDO = SD[15]; ACK1 = I2C_SDAT; end 6'd13: SDO = SD[14]; 6'd14: SDO = SD[14]; 6'd16: SDO = SD[12]; 6'd16: SDO = SD[12]; 6'd17: SDO = SD[13]; 6'd18: SDO = SD[13]; 6'd19: SDO = SD[8]; 6'd19: SDO = SD[8]; 6'd20: SDO = 1'b1; // ACK // Data 6'd21: begin SDO = SD[7]; ACK2 = I2C_SDAT; end 6'd22: SDO = SD[6]; 6'd23: SDO = SD[6]; 6'd24: SDO = SD[1]; 6'd25: SDO = SD[1]; 6'd26: SDO = SD[1]; 6'd27: SDO = SD[1]; 6'd28: SDO = SD[1]; 6'd29: SDO = SD[1]; 6'd29: SDO = SD[1]; 6'd29: SDO = SD[1]; 6'd21: begin SDO = 1'b1; // ACK // Stop 6'd30: begin SDO = 1'b1; END = 1; end endcase end ``` ### de2\_sram\_controller.vhd ``` library ieee; use ieee.std_logic_l164.all; entity de2_sram_controller is port ( signal chipselect : in std_logic; signal write, read : in std_logic; signal address : in std_logic_vector(17 downto 0); signal address : in std_logic_vector(15 downto 0); signal writedata : in std_logic_vector(15 downto 0); signal byteenable : in std_logic_vector(15 downto 0); signal SRAM_DQ : inout std_logic_vector(15 downto 0); signal SRAM_DDR : out std_logic_vector(17 downto 0); signal SRAM_UB_N, SRAM_LB_N : out std_logic; signal SRAM_UB_N, SRAM_CE_N : out std_logic; signal SRAM_OE_N : out std_logic ); end de2_sram_controller; architecture dp of de2_sram_controller is begin SRAM_DQ <= writedata when write = '1' else (others => '2'); readdata <= SRAM_DQ; SRAM_ADDR <= address; SRAM_UB_N <= not byteenable(1); SRAM_LB_N <= not byteenable(0); SRAM_CE_N <= not chipselect; ``` # de2\_sram\_controller\_hw.tcl ``` # TCL File Generated by Component Editor 7.2 on: # Thu Apr 05 15:54:15 EDT 2012 # DO NOT MODIFY set_source_file "de2_sram_controller.vhd" set_module_description "" set_module_property "className" "de2_sram_controller" set_module_property "group" "" set_module_property "group" "" set_module_property "ibraries" [ list "ieee.std_logic_l164.all" "std.standard.all" ] set_module_property "synthesisFiles" "de2_sram_controller.vhd" ``` ``` # Module parameters # Interface export_0 add_interface "export_0" "conduit" "start" "asynchronous" # Ports in interface export_0" "SRAM_DQ" "export" add_port_to_interface "export_0" "SRAM_DDR" "export" add_port_to_interface "export_0" "SRAM_BDR" "export" add_port_to_interface "export_0" "SRAM_LB_N" "export" add_port_to_interface "export_0" "SRAM_LB_N" "export" add_port_to_interface "export_0" "SRAM_ME_N" "export" add_port_to_interface "export_0" "SRAM_OE_N" "export" add_port_to_interface "export_0" "SRAM_CE_N" "export" # Interface avalon slave 0 add_interface "avalon_slave_0" "avalon" "slave" "asynchronous" set_interface_property "avalon_slave_0" "isNonVolatileStorage" "false" set_interface_property "avalon_slave_0" "burstOnBurstBoundariesOnly" "false" set_interface_property "avalon_slave_0" "readLatency" "0" set_interface_property "avalon_slave_0" "holdTime" "0" set_interface_property "avalon_slave_0" "printableDevice" "false" set_interface_property "avalon_slave_0" "readWaitTime" "1" set_interface_property "avalon_slave_0" "setupTime" "0" set_interface_property "avalon_slave_0" "addressAlignment" "DYNAMIC" set_interface_property "avalon_slave_0" "writeWaitTime" "0" set interface property "avalon slave 0" "timingUnits" "Cycles" set_interface_property "avalon_slave_0" "minimumUninterruptedRunLength" "1" set_interface_property "avalon_slave_0" "isMemoryDevice" "true" set_interface_property "avalon_slave_0" "linewrapBursts" "false" set_interface_property "avalon_slave_0" "maximumPendingReadTransactions" "0" # Ports in interface avalon_slave_0 add_port_to_interface "avalon_slave_0" "chipselect" "chipselect" add_port_to_interface "avalon_slave_0" "write" "write" add_port_to_interface "avalon_slave_0" "read" "read" add_port_to_interface "avalon_slave_0" "address" "address" add_port_to_interface "avalon_slave_0" "readdata" "readdata" add_port_to_interface "avalon_slave_0" "writedata" "writedata" add_port_to_interface "avalon_slave_0" "byteenable" "byteenable" ``` ## $de2\_wm8731\_audio.vhd$ This file has not been modified from its original version. ## guitar\_top.vhd ``` - DE2 top-level module - Stephen A. Edwards, Columbia University, sedwards@cs.columbia.edu - From an original by Terasic Technology, Inc. - (DE2_TOP.v, part of the DE2 system board CD supplied by Altera) - library ieee; use ieee.std_logic_l164.all; use ieee.std_logic_l164.all; use ieee.rumeric_std.all; entity guitar_top is port ( signal CLOCK_50 : in std_logic; SRAM_DQ : inout std_logic_vector(15 downto 0); SRAM_DDR : out std_logic_vector(17 downto 0); KSY: in std_logic_vector(3 downto 0); SRAM_UB_N, SRAM_UB_N, SRAM_WE_N, ``` ``` SRAM_CE_N, SRAM_OE_N : out std_logic ; GPIO_0, - GPIO Connection 0 _1 : inout std_logic_vector(35 downto 0) - GPIO Connection 1 GPIO_1 : ); end guitar_top; architecture datapath of guitar_top is signal reset_n :std_logic; signal new_res:std_logic; signal audio_clock : unsigned(1 downto 0) := "00"; signal counter : unsigned(15 downto 0); begin process (CLOCK_50) begin begin if rising_edge(CLOCK_50) then if counter = x"ffff" then reset_n <= '1';</pre> reset_n <= '1'; else reset_n <= '0'; counter <= counter + 1; end if; end if; end process; process (CLOCK_50) begin if rising_edge(CLOCK_50) then audio_clock <= audio_clock + "1";</pre> end if; end process; end process; nios: entity work.nios_system port map ( clk => CLOCK_50, reset_n => reset_n, RRAM_ADDR_from_the_sram => SRAM_ADDR, SRAM_CE_N, RRAM_DO_to_and_from_the_sram => SRAM_CE_N, SRAM_DO_to_and_from_the_sram => SRAM_DO, SRAM_DO_to_and_from_the_sram => SRAM_DO, SRAM_DO_to_and_from_the_sram => SRAM_DO, SRAM_DO_to_and_from_the_sram => SRAM_DO_N, SRAM_DO_trom_the_sram SRAM_DO_TROM_DO_N, S SWITCH 3 to the InputController inst => '1', SWITCH 4 to the InputController inst => '1', SWITCH 5 to the InputController2 inst => GPIO_0(0), -SWITCH_1 to the InputController2 inst => GPIO_0(1), -SWITCH_2 to the InputController2 inst => GPIO_0(1), -SWITCH_3 to the InputController2 inst => GPIO_0(2), -SWITCH_3 to the InputController2 inst => GPIO_0(3), -SWITCH_4 to, the InputController2 inst => GPIO_0(4) SWITCH_5 to the InputController2 inst => GPIO_0(4) SWITCH_5 to the InputController2 inst => GPIO_0(4) SWITCH_5 to the InputController2 inst => KEY(1), SWITCH_5 to the InputController2 inst => '1', SWITCH_5 to the InputController2 inst => '1', SWITCH_5 to the InputController2 inst => '1', SWITCH_5 to the InputController3 inst => GPIO_0(0), -SWITCH_5 to the InputController3 inst => GPIO_0(0), -SWITCH_5 to the InputController3 inst => GPIO_0(0), -SWITCH_5 to the InputController3 inst => GPIO_0(0), -SWITCH_5 to the InputController3 inst => GPIO_0(3), -SWITCH_5 to the InputController3 inst => GPIO_0(3), -SWITCH_5 to the InputController3 inst => GPIO_0(3), -SWITCH_5 to the InputController3 inst => '1', SWITCH_5 to the InputController3 inst => '1', SWITCH_5 to the InputController3 inst => '1', SWITCH_5 to the InputController4 inst => GPIO_0(0), -SWITCH_5 to the InputController4 inst => GPIO_0(0), -SWITCH_5 to the InputController4 inst => GPIO_0(0), -SWITCH_5 to the InputController4 inst => GPIO_0(0), -SWITCH_5 to the InputController4 inst => GPIO_0(0), -SWITCH_6 to the InputController4 inst => GPIO_0(0), -SWITCH_6 to the InputController4 inst => '1', SWITCH_6 to the InputController4 inst => '1', SWITCH_6 to the InputController4 inst => '1', SWITCH_6 to the InputController4 inst => '1', SWITCH_6 to the InputController4 inst => '1', SWITCH_6 to the InputController6 inst => '1', SWITCH_6 to the InputController6 inst => '1', SWITCH_6 to the InputController6 inst => '1', SWITCH_6 to the InputController6 inst => '1', SWITCH_6 to the InputController6 inst => '1', SWITCH_6 to the InputController6 inst => '1', SWITCH_6 to the I SWITCH_5_to_the_InputController5_inst => '1' ``` ``` end datapath; ``` ## InputController.vhd ``` library ieee; use ieee.std_logic_1164.all; use ieee.numeric_std.all; entity InputController is port ( clk : in std_logic; reset_n : in std_logic; read : in std_logic; write : in std_logic; chipselect : in std_logic; address : in unsigned(9 downto 0); readdata : out unsigned(15 downto 0); writedata : in unsigned(15 downto 0); inter : out std_logic; -To switches SWITCH_1 : in std_logic; SWITCH_2 : in std_logic; SWITCH_3 : in std_logic; SWITCH_4 : in std_logic; SWITCH_5 : in std_logic end InputController; architecture rtl of InputController is type states is (IDLE, PRESSED, WAITST); signal state, next_state : states; signal we:std_Logic; signal reset:std_logic; signal counter: integer; - A bunch of signals for the button - The button clicks are first debounced and then - Pulsed - The naming follow this convention: - Initial SWITCH_1 _____-____ - Debounced DSWITCH_1 _____-----_ - Pulsed PSWITCH_1 ____ signal DSWITCH_1:std_logic; signal PSWITCH_1:std_logic; ``` ``` -Switch 2 signal DSWITCH_2:std_logic; signal PSWITCH_2:std_logic; -Switch 3 signal DSWITCH_3:std_logic; signal PSWITCH_3:std_logic; -Switch 4 signal DSWITCH_4:std_logic; signal PSWITCH_4:std_logic; signal DSWITCH_5:std_logic; signal PSWITCH_5:std_logic; component debouncer is port( clk : in std_logic; key_in : in std_logic; key_out : out std_logic; reset : in std_logic end component debouncer; component pulser is port( clk : in std_logic; key_in : in std_logic; key_out : out std_logic; reset : in std_logic ); end component pulser; begin -Reset reset <= not reset_n;</pre> we <= '1' when chipselect ='1' and write='1' else '0'; -Debouncers D1: debouncer port map(clk,SWITCH_1,DSWITCH_1,reset); D2: debouncer port map(clk,SWITCH_2,DSWITCH_2,reset); D3: debouncer port map(clk,SWITCH_3,DSWITCH_3,reset); D4: debouncer port map(clk,SWITCH_4,DSWITCH_4,reset); D5: debouncer port map(clk,SWITCH_5,DSWITCH_5,reset); P1: pulser port map(clk,DSWITCH_1,PSWITCH_1,reset); P2: pulser port map(clk,DSWITCH_2,PSWITCH_2,reset); P3: pulser port map(clk,DSWITCH_3,PSWITCH_3,reset); P4: pulser port map(clk,DSWITCH_4,PSWITCH_4,reset); P5: pulser port map(clk,DSWITCH_5,PSWITCH_5,reset); -FSM Strandard next_state => state process(clk) begin if(rising_edge(clk)) then ``` ``` if( reset_n='0' ) state <= IDLE; else state <= next_state; if (state = PRESSED) then counter <=0; else counter <=counter +1; end if; end if; end if; end process; -Combinational process process (state,SWITCH_1,we) -By default reset the interuption signal inter <= '0'; next_state <= state; case state is -Waiting for a button click when IDLE => if (PSWITCH_1 = '0' or PSWITCH_2 = '0' or PSWITCH_3 = '0' or PSWITCH_4 = '0' or PSWITCH_5 = '0' ) then next_state <= PRESSED; end if; -A button has been pressed -Stay into this state until the interuption has been cleared when PRESSED => inter <='1'; if (we='1') then next_state <= WAITST; end if; when WAITST => inter <='0'; if (counter > 30000) then next_state <= IDLE; end if; end case; end process; ``` ## InputController\_hw.tcl This file has not been modified from its original version. ## InputController\_inst.vhd ``` -Legal Notice: (C)2007 Altera Corporation. All rights reserved. Your -use of Altera Corporation's design tools, logic functions and other -software and tools, and its AMPP partner logic functions, and any -output files any of the foregoing (including device programming or -simulation files), and any associated documentation or information are -expressly subject to the terms and conditions of the Altera Program -License Subscription Agreement or other applicable license agreement, -including, without limitation, that your use is for the sole purpose -of programming logic devices manufactured by Altera and sold by Altera -or its authorized distributors. Please refer to the applicable -agreement for further details. - turn off superfluous VHDL processor warnings - altera message_level Level1 - altera message_off 10034 10035 10036 10037 10230 10240 10030 library altera; use altera.altera_europa_support_lib.all; library ieee; use ieee.std_logic_l164.al1; use ieee.std_logic_arith.all; use ieee.std_logic_unsigned.all; entity InputController_inst is port ( - inputs: signal SWITCH_1: IN STD_LOGIC; signal SWITCH_2: IN STD_LOGIC; signal SWITCH_3: IN STD_LOGIC; signal SWITCH_4: IN STD_LOGIC; signal SWITCH_5: IN STD_LOGIC; signal SWITCH_5: IN STD_LOGIC; signal address: IN STD_LOGIC; signal address: IN STD_LOGIC, signal chipselect: IN STD_LOGIC; signal chipselect: IN STD_LOGIC; signal reset_n: IN STD_LOGIC; signal reset_n: IN STD_LOGIC; signal write: IN STD_LOGIC; signal write : IN STD_LOGIC; signal writedata: IN STD_LOGIC; entity InputController_inst is - outputs: signal inter: OUT STD_LOGIC; signal readdata: OUT STD_LOGIC_VECTOR (15 DOWNTO 0) end entity InputController_inst; \label{lem:controller_inst} \mbox{architecture europa of InputController\_inst is} \\ \mbox{component InputController is} \\ - outputs: signal inter: OUT STD_LOGIC; signal readdata: OUT STD_LOGIC_VECTOR (15 DOWNTO 0) ); end component InputController; signal internal_inter : STD_LOGIC; signal internal_readdata : STD_LOGIC_VECTOR (15 DOWNTO 0); -the_InputController, which is an e_instance the_InputController: InputController2 port map( inter => internal_inter, readdata => internal_readdata, SWITCH_1 => SWITCH_1, ``` ### InputController2\_inst.vhd begin ``` -Legal Notice: (C)2007 Altera Corporation. All rights reserved. Your -use of Altera Corporation's design tools, logic functions and other -software and tools, and its AMPP partner logic functions, and any -output files any of the foregoing (including device programming or -simulation files), and any associated documentation or information are -expressly subject to the terms and conditions of the Altera Program -License Subscription Agreement or other applicable license agreement, -including, without limitation, that your use is for the sole purpose -of programming logic devices manufactured by Altera and sold by Altera -or its authorized distributors. Please refer to the applicable -agreement for further details. -agreement for further details. - turn off superfluous VHDL processor warnings - altera message_level Level1 - altera message_off 10034 10035 10036 10037 10230 10240 10030 library altera; use altera.altera_europa_support_lib.all; library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_arith.all; use ieee.std_logic_unsigned.all; entity InputController2 inst is port ( - outputs: signal inter : OUT STD_LOGIC; signal readdata : OUT STD_LOGIC_VECTOR (15 DOWNTO 0) ); end entity InputController2_inst; \label{localization} {\tt architecture\ europa\ of\ InputController2\_inst\ is} \\ {\tt component\ InputController2\ is} port ( inputs: -inputs: signal SWITCH_1: IN STD_LOGIC; signal SWITCH_2: IN STD_LOGIC; signal SWITCH_3: IN STD_LOGIC; signal SWITCH_4: IN STD_LOGIC; signal SWITCH_5: IN STD_LOGIC; signal address: IN STD_LOGIC, signal address: IN STD_LOGIC, signal chipselect: IN STD_LOGIC; signal ck: IN STD_LOGIC; signal read: IN STD_LOGIC; signal read: IN STD_LOGIC; signal write: IN STD_LOGIC; signal write: IN STD_LOGIC; signal write IN STD_LOGIC; - outputs: signal inter: OUT STD_LOGIC; signal readdata: OUT STD_LOGIC_VECTOR (15 DOWNTO 0) end component InputController2; signal internal_inter : STD_LOGIC; signal internal_readdata : STD_LOGIC_VECTOR (15 DOWNTO 0); ``` ``` -the_InputController2, which is an e_instance the_InputController2 : InputController2 port map( inter => internal_inter, readdata => internal_readdata, SWITCH_1 => SWITCH_1, SWITCH_2 => SWITCH_2, SWITCH_3 => SWITCH_3, SWITCH_4 => SWITCH_3, SWITCH_5 => SWITCH_5, address => address, chipselect => chipselect, clk => clk, read => read, reset_n => reset_n, write => write, writedata => writedata ); --whdl renameroo for output signals inter <= internal_inter; -vhdl renameroo for output signals readdata <= internal_readdata; end europa; ``` ### InputController3\_inst.vhd ``` -Legal Notice: (C) 2007 Altera Corporation. All rights reserved. Your -use of Altera Corporation's design tools, logic functions and other -software and tools, and its AMP partner logic functions, and any -output files any of the foregoing (including device programming or -simulation files), and any associated documentation or information are -expressly subject to the terms and conditions of the Altera Program -license Subscription Agreement or other applicable license agreement, -including, without limitation, that your use is for the sole purpose -of programming logic devices manufactured by Altera and sold by Altera -or its authorized distributors. Please refer to the applicable -agreement for further details. - turn off superfluous VHDL processor warnings - altera message_level Level1 - altera message_level Level1 - altera message_level Level1 - altera message_level Level1 - altera active activ ``` ``` end component InputController3; signal internal_inter: STD_LOGIC; signal internal_readdata: STD_LOGIC_VECTOR (15 DOWNTO 0); begin -the_InputController3, which is an e_instance the_InputController3: InputController3 port map( inter => internal_inter, readdata => internal_readdata, SWITCH_1 => SWITCH_1, SWITCH_2 => SWITCH_2, SWITCH_3 => SWITCH_3, SWITCH_4 => SWITCH_4, SWITCH_5 => SWITCH_5, address => address, chipselect => chipselect, clk => clk, read => read, reset_n => reset_n, write => write, writedata => writedata ); -vhdl renameroo for output signals inter <= internal_inter; -vhdl renameroo for output signals readdata <= internal_readdata; end europa;</pre> ``` ## InputController4\_inst.vhd ``` -Legal Notice: (C)2007 Altera Corporation. All rights reserved. Your -use of Altera Corporation's design tools, logic functions and other -software and tools, and its AMPP partner logic functions, and any -output files any of the foregoing (including device programming or -simulation files), and any associated documentation or information are -expressly subject to the terms and conditions of the Altera Program -license Subscription Agreement or other applicable license agreement, -including, without limitation, that your use is for the sole purpose -of programming logic devices manufactured by Altera and sold by Altera -or its authorized distributors. Please refer to the applicable -agreement for further details. - turn off superfluous VHDL processor warnings - altera message_level Levell - altera message_level Levell - altera message_level Levell : library altera; use altera.altera_europa_support_lib.all; use ieee.std_logic_arith.all; use ieee.std_logic_arith.all; use ieee.std_logic_arith.all; use ieee.std_logic_arith.all; signal SWITCH_1 : IN STD_LOGIC; signal SWITCH_2 : IN STD_LOGIC; signal SWITCH_3 : IN STD_LOGIC; signal SWITCH_4 : IN STD_LOGIC; signal SWITCH_5 : IN STD_LOGIC; signal SWITCH_5 : IN STD_LOGIC; signal SWITCH_6 : IN STD_LOGIC; signal chipselect : IN STD_LOGIC; signal read : IN STD_LOGIC; signal read : IN STD_LOGIC; signal write : IN STD_LOGIC; signal write : IN STD_LOGIC; signal write are in STD_LOGIC; signal inter : OUT STD_LOGIC; signal inter : OUT STD_LOGIC; signal inter : OUT STD_LOGIC; signal inter : IN STD_LOGIC; signal sWITCH_1 : IN STD_LOGIC; signal sWITCH_2 : IN STD_LOGIC; signal sWITCH_3 : IN STD_LOGIC; signal sWITCH_4 : IN STD_LOGIC; signal SWITCH_5 chipselect : IN STD_LOGIC; signal read : IN STD_LOGIC ``` ### InputController5\_inst.vhd ``` -Legal Notice: (C)2007 Altera Corporation. All rights reserved. Your -use of Altera Corporation's design tools, logic functions and other -software and tools, and its AMPP partner logic functions, and any output files any of the foregoing (including device programming or -simulation files), and any associated documentation or information are expressly subject to the terms and conditions of the Altera Program -License Subscription Agreement or other applicable license agreement, -including, without limitation, that your use is for the sole purpose of programming logic devices manufactured by Altera and sold by Altera or its authorized distributors. Please refer to the applicable -agreement for further details. - turn off superfluous VHDL processor warnings - altera message_level Levell - altera message_level Levell - altera message_off 10034 10035 10036 10037 10230 10240 10030 library altera; use altera_europa_support_lib.all; library ieee; use leee.std_logic_arith.all; use leee.std_logic_arith.all; use leee.std_logic_arith.all; use leee.std_logic_arith.all; use leee.std_logic_arith.all; signal SWITCH_1 : IN STD_LOGIC; signal SWITCH_2 : IN STD_LOGIC; signal SWITCH_3 : IN STD_LOGIC; signal SWITCH_4 : IN STD_LOGIC; signal SWITCH_5 : IN STD_LOGIC; signal address : IN STD_LOGIC; signal chipselect : IN STD_LOGIC; signal chipselect : IN STD_LOGIC; signal reset_n : IN STD_LOGIC; signal reset_n : IN STD_LOGIC; signal writedata : IN STD_LOGIC; signal writedata : IN STD_LOGIC; signal writedata : IN STD_LOGIC; signal writedata : IN STD_LOGIC; signal writedata : IN STD_LOGIC; signal inter : OUT STD_LOGIC, vector (15 DOWNTO 0); - outputs: signal inter : IN STD_LOGIC; signal SWITCH_1 : IN STD_LOGIC; signal SWITCH_2 : IN STD_LOGIC; signal SWITCH_2 : IN STD_LOGIC; signal SWITCH_3 S ``` ## InputController6\_inst.vhd ``` -Legal Notice: (C)2007 Altera Corporation. All rights reserved. Your -use of Altera Corporation's design tools, logic functions and other -software and tools, and its AMPP partner logic functions, and any -output files any of the foregoing (including device programming or -simulation files), and any associated documentation or information are -expressly subject to the terms and conditions of the Altera Program -License Subscription Agreement or other applicable license agreement, -including, without limitation, that your use is for the sole purpose of programming logic devices manufactured by Altera and sold by Altera or its authorized distributors. Please refer to the applicable -agreement for further details. - turn off superfluous VHDL processor warnings - altera message_level Level1 - altera message_level Level1 - altera message_level Level1 - altera message_level Level1 - altera altera_europa_support_lib.all; library ieee; use ieee.std_logic_ll64.all; use ieee.std_logic_grith.all; use ieee.std_logic_arith.all; use ieee.std_logic_mrith.all; entity InputController6_inst is port ( - inputs: signal SWITCH_1 : IN STD_LOGIC; signal SWITCH_2 : IN STD_LOGIC; signal SWITCH_3 : IN STD_LOGIC; signal SWITCH_4 : IN STD_LOGIC; signal SWITCH_5 : IN STD_LOGIC; signal SWITCH_5 : IN STD_LOGIC; signal clk: IN STD_LOGIC; signal clk: IN STD_LOGIC; signal read : IN STD_LOGIC; signal read : IN STD_LOGIC; signal read: IN STD_LOGIC; signal writedata : IN STD_LOGIC; signal writedata : IN STD_LOGIC; signal writedata : IN STD_LOGIC; signal inter : OUT STD_LOGIC; signal inter : OUT STD_LOGIC; signal inter : OUT STD_LOGIC; signal readdata : OUT STD_LOGIC_VECTOR (15 DOWNTO 0); - outputs: signal inter tout std_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic_logic ``` ``` - inputs: signal SWITCH_1: IN STD_LOGIC; signal SWITCH_2: IN STD_LOGIC; signal SWITCH_4: IN STD_LOGIC; signal SWITCH_4: IN STD_LOGIC; signal SWITCH_5: IN STD_LOGIC; signal SWITCH_5: IN STD_LOGIC; signal SWITCH_5: IN STD_LOGIC; signal address: IN STD_LOGIC; signal chipselect: IN STD_LOGIC; signal chipselect: IN STD_LOGIC; signal read: IN STD_LOGIC; signal read: IN STD_LOGIC; signal rest_n: IN STD_LOGIC; signal write of the standard ``` ## jtag\_uart.vhd This file has not been modified from its original version. ## nios\_system.bsf This file has not been modified from its original version. ## nios\_system.ptf This file has not been modified from its original version. # nios\_system.qip ``` set_global_assignment -name SOURCE_FILE [file join $::quartus(qip_path) /home/user3/spring12/imf2108/embsyscolspr2012/WORK/AWESOME_GUITAR/de2_sram_controller_hw.tcl] set_global_assignment -name VHDL_FILE [file join $::quartus(qip_path) /home/user3/spring12/imf2108/embsyscolspr2012/WORK/AWESOME_GUITAR/de2_sram_controller.vhd] set_global_assignment -name SOURCE_FILE [file join $::quartus(qip_path) /home/user3/spring12/imf2108/embsyscolspr2012/WORK/AWESOME_GUITAR/InputController_hw.tcl] set_global_assignment -name VHDL_FILE [file join $::quartus(qip_path) /home/user3/spring12/imf2108/embsyscolspr2012/WORK/AWESOME_GUITAR/InputController.vhd] set_global_assignment -name SOURCE_FILE [file join $::quartus(qip_path) /home/user3/spring12/imf2108/Desktop/InputController2_hw.tcl] set_global_assignment -name VHDL_FILE [file join $::quartus(qip_path) /home/user3/spring12/imf2108/Desktop/InputController2.vhd] ``` ``` set_global_assignment -name VHDL_FILE [file join $::quartus(qip_path) /home/user3/spring12/imf2108/Desktop/InputController3_nw.tcl] set_global_assignment -name VHDL_FILE [file join $::quartus(qip_path) /home/user3/spring12/imf2108/Desktop/InputController3_nw.tcl] set_global_assignment -name VHDL_FILE [file join $::quartus(qip_path) /home/user3/spring12/imf2108/Desktop/InputController4_hw.tcl] set_global_assignment -name VHDL_FILE [file join $::quartus(qip_path) /home/user3/spring12/imf2108/Desktop/InputController4.vhd] set_global_assignment -name VHDL_FILE [file join $::quartus(qip_path) /home/user3/spring12/imf2108/Desktop/InputController5_hw.tcl] set_global_assignment -name VHDL_FILE [file join $::quartus(qip_path) /home/user3/spring12/imf2108/Desktop/InputController5_vhd] set_global_assignment -name VHDL_FILE [file join $::quartus(qip_path) /home/user3/spring12/imf2108/Desktop/InputController6_hw.tcl] set_global_assignment -name VHDL_FILE [file join $::quartus(qip_path) /home/user3/spring12/imf2108/Desktop/InputController6_hw.tcl] ``` #### nios\_system.sopc This file has not been modified from its original version. ### nios\_system\_generation\_script This file has not been modified from its original version. ### nios\_system\_log.txt ``` Altera SOPC Builder Version 7.20 Build 151 Copyright (c) 1999-2007 Altera Corporation. All rights reserved. # 2012.05.23 22:23:07 (*) mk_custom_sdk starting # 2012.05.23 22:23:07 (*) Reading project /home/user3/spring12/imf2108/embsyscolspr2012/WORK/AWESOME_GUITAR/nios_system.ptf. # 2012.05.23 22:23:07 (*) Finding all CPUs # 2012.05.23 22:23:07 (*) Finding all available components # 2012.05.23 22:23:07 (*) Reading /home/user3/spring12/imf2108/embsyscolspr2012/WORK/AWESOME_GUITAR/.sopc_builder/install.ptf # 2012.05.23 22:23:08 (*) Found 67 components # 2012.05.23 22:23:08 (*) Finding all peripherals # 2012.05.23 22:23:08 (*) Finding software components # 2012.05.23 22:23:09 (*) (Legacy SDK Generation Skipped) # 2012.05.23 22:23:09 (*) (All TCL Script Generation Skipped) # 2012.05.23 22:23:09 (*) (No Libraries Built) # 2012.05.23 22:23:09 (*) (Contents Generation Skipped) # 2012.05.23 22:23:09 (*) mk_custom_sdk finishing # 2012.05.23 22:23:09 (*) Starting generation for system: nios_system. # 2012.05.23 22:23:10 (*) Running Generator Program for cpu # 2012.05.23 22:23:11 (*) Checking for plaintext license. # 2012.05.23 22:23:11 (*) Couldn't query license setup in Quartus directory /opt/altera/altera7.2/quartus # 2012.05.23 22:23:11 (*) Defaulting to contents of LM_LICENSE_FILE environment variable # 2012.05.23 22:23:11 (*) Plaintext license not found. # 2012.05.23 22:23:11 (*) Checking for encrypted license (non-evaluation). # 2012.05.23 22:23:11 (*) Couldn't query license setup in Quartus directory /opt/altera/altera7.2/quartus # 2012.05.23 22:23:11 (*) Defaulting to contents of LM_LICENSE_FILE environment variable # 2012.05.23 22:23:11 (*) Encrypted license found. SOF will not be time-limited. # 2012.05.23 22:23:20 (*) Creating encrypted HDL \# 2012.05.23 22:23:22 (*) Running Generator Program for jtag_uart \# 2012.05.23 22:23:23 (*) Making arbitration and system (top) modules. # 2012.05.23 22:23:30 (*) Generating Quartus symbol for top level: nios_system # 2012.05.23 22:23:30 (*) Generating Symbol /home/user3/spring12/imf2108/embsyscolspr2012/WORK/AWESOME_GUITAR/nios_system.bsf # 2012.05.23 22:23:30 (*) Creating command-line system-generation script: /home/user3/spring12/imf2108/embsysco1spr2012/WORK/AWESOME_GUITAR/nios_system_generation_script # 2012.05.23 22:23:30 (*) Running setup for HDL simulator: modelsim \# 2012.05.23 22:23:30 (*) Setting up Quartus with nios_system_setup_quartus.tcl /opt/altera/altera7.2/quartus/bin/quartus_sh -t nios_system_setup_quartus.tcl ``` ``` Info: to the terms and conditions of the Altera Program License Info: Subscription Agreement, Altera MegaCore Function License Info: Agreement, or other applicable license agreement, including, Info: without limitation, that your use is for the sole purpose of Info: programming logic devices manufactured by Altera and sold by Info: Altera or its authorized distributors. Please refer to the In fo: applicable agreement for further details. Info: Processing started: Wed May 23 22:23:30 2012 Info: Command: quartus_sh -t nios_system_setup_quartus.tcl Info: Evaluation of Tcl script nios_system_setup_quartus.tcl was successful Info: Quartus II Shell was successful. 0 errors, 0 warnings Info: Processing ended: Wed May 23 22:23:31 2012 Info: Elapsed time: 00:00:01 # 2012.05.23 22:23:31 (*) Completed generation for system: nios_system. # 2012.05.23 22:23:31 (*) THE FOLLOWING SYSTEM ITEMS HAVE BEEN GENERATED: SYSTEM HDL Model: /home/user3/springl2/imf2108/embsyscolspr2012/WORK/AWESOME_GUITAR/nios_system.ptf System Generation Script: /home/user3/springl2/imf2108/embsyscolspr2012/WORK/AWESOME_GUITAR/nios_system_generation_script # 2012.05.23 22:23:31 (*) SUCCESS: SYSTEM GENERATION COMPLETED. Press 'Exit' to exit. ``` ## nios\_system.ptf.pre\_generation\_ptf This file has not been modified from its original version. ## nios\_system\_setup\_quartus.tcl ``` # Caution: this file may be regenerated by SOPC Builder. User edits will be lost. project_open -current_revision "/home/user3/spring12/imf2108/embsyscolspr2012/WORK/AWESOME_GUITAR/AWESOME_GUITAR.qpf" set_global_assignment -name VHDL_FILE altera_europa_support.vhd project_close ``` ## pulser.vhd ``` -Pulser generator -When the input signal switches to 1 -it generates a pulse library ieee; use ieee.std_logic_1164.all; use ieee.numeric_std.all; entity pulser is port (clk : in std_logic; key_in : in std_logic; key_out : out std_logic; reset : in std_logic ); end pulser ; architecture Al of pulser is type states is (ZERO, ONE_PULSE, ONE_STANDBY); signal state, next_state : states; begin -FSM Strandard next_state => state process(clk) begin if(rising_edge(clk)) then if(reset='1') then state <= ZERO; eise state <= next_state; end if; end if; end process; -Computation of the next state process (state, key_in) begin next_state <= state; case state is -State ZERO -Signal generated 0 when ZERO => ``` ### sopc\_builder\_log.txt This file has not been modified from its original version. ### sram.vhd ``` -Legal Notice: (C) 2007 Altera Corporation. All rights reserved. Your -use of Altera Corporation's design tools, logic functions and other -software and tools, and its AMPP partner logic functions, and any -output files any of the foregoing (including device programming or -simulation files), and any associated documentation or information are -expressly subject to the terms and conditions of the Altera Program -license Subscription Agreement or other applicable license agreement, -including, without limitation, that your use is for the sole purpose -of programming logic devices manufactured by Altera and sold by Altera -or its authorized distributors. Please refer to the applicable -agreement for further details. - turn off superfluous VHDL processor warnings - altera message_level Level1 - altera message_level Level1 - altera message_level Level1 - altera altera, surpage and the selection of ``` ``` signal SRAM_WE_N : OUT STD_LOGIC; signal SRAM_WE_N : OUT STD_LOGIC; signal readdata : OUT STD_LOGIC_VECTOR (15 DOWNTO 0) ); end component de2_sram_controller; signal internal_SRAM_CE_N : STD_LOGIC_VECTOR (17 DOWNTO 0); signal internal_SRAM_CE_N : STD_LOGIC; signal internal_SRAM_CE_N : STD_LOGIC; signal internal_SRAM_DE_N : STD_LOGIC; signal internal_SRAM_UE_N : STD_LOGIC; signal internal_SRAM_WE_N : STD_LOGIC; signal internal_SRAM_WE_N : STD_LOGIC; signal internal_SRAM_WE_N : STD_LOGIC; signal internal_SRAM_WE_N : STD_LOGIC, signal internal_SRAM_WE_N : STD_LOGIC_VECTOR (15 DOWNTO 0); begin -the_de2_sram_controller : de2_sram_controller port map( SRAM_DDR => internal_SRAM_ADDR, SRAM_DDR => internal_SRAM_CE_N, SRAM_CE_N => internal_SRAM_CE_N, SRAM_DD_N => internal_SRAM_DD, SRAM_DD_N => internal_SRAM_DE_N, SRAM_WE_N => internal_SRAM_DE_N, SRAM_WE_N => internal_SRAM_WE_N, readdata => internal_SRAM_WE_N, readdata => internal_SRAM_WE_N, readdata => internal_SRAM_DE_N, SRAM_DEN => write, write=> writedata ); -vhd1 renameroo for output signals SRAM_CE_N = internal_SRAM_DDR; -vhd1 renameroo for output signals SRAM_CE_N = internal_SRAM_LE_N; -vhd1 renameroo for output signals SRAM_CE_N = internal_SRAM_DE_N; -vhd1 renameroo for output signals SRAM_CE_N = internal_SRAM_DE_N; -vhd1 renameroo for output signals SRAM_UE_N <= internal_SRAM_UE_N; -vhd1 renameroo for output signals SRAM_WE_N <= internal_SRAM_WE_N; -vhd1 renameroo for output signals SRAM_WE_N <= internal_SRAM_WE_N; -vhd1 renameroo for output signals SRAM_WE_N <= internal_SRAM_WE_N; -vhd1 renameroo for output signals SRAM_WE_N <= internal_SRAM_WE_N; -vhd1 renameroo for output signals SRAM_WE_N <= internal_SRAM_WE_N; -vhd1 renameroo for output signals end europa; end europa; end europa; end europa; end europa; end europa; end eu ``` #### timer.vhd ``` -Legal Notice: (C)2007 Altera Corporation. All rights reserved. Your -use of Altera Corporation's design tools, logic functions and other -software and tools, and its AMPP partner logic functions, and any -output files any of the foregoing (including device programming or -simulation files), and any associated documentation or information are -expressly subject to the terms and conditions of the Altera Program -License Subscription Agreement or other applicable license agreement, -including, without limitation, that your use is for the sole purpose -of programming logic devices manufactured by Altera and sold by Altera -or its authorized distributors. Please refer to the applicable -agreement for further details. - turn off superfluous VHDL processor warnings - altera message_level Level1 - altera message_level Level1 - altera message_level Level1 - altera message_level Level1 - library altera; use altera.altera_europa_support_lib.all; library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_arith.all; use ieee.std_logic_arith.all; use ieee.std_logic_unsigned.all; entity timer is port ( - inputs: signal address : IN STD_LOGIC_VECTOR (2 DOWNTO 0); signal chipselect : IN STD_LOGIC; signal reset_n : IN STD_LOGIC; signal reset_n : IN STD_LOGIC; signal write_n : IN STD_LOGIC; signal write_n : IN STD_LOGIC; signal writedata : OUT STD_LOGIC, signal irq : OUT STD_LOGIC; signal irq : OUT STD_LOGIC; signal address : OUT STD_LOGIC_VECTOR (15 DOWNTO 0) ); end entity timer; architecture europa of timer is signal clk_en : STD_LOGIC; ``` ``` signal control_continuous: STD_LOGIC; signal control_interrupt_enable: STD_LOGIC; signal control_register: STD_LOGIC; signal control_wr_strobe: STD_LOGIC; signal control_wr_strobe: STD_LOGIC; signal counter_is_running: STD_LOGIC; signal counter_is_rero: STD_LOGIC; signal counter_is_rero: STD_LOGIC; signal counter_is_apens. signal counter_strobe: STD_LOGIC_VECTOR (31 DOWNTO 0); signal delayed_unxcounter_is_zeroxx0: STD_LOGIC; signal do_start_counter: STD_LOGIC; signal force_reload: STD_LOGIC; signal force_reload: STD_LOGIC; signal period_hr_register: STD_LOGIC_VECTOR (31 DOWNTO 0); signal period_hr_register: STD_LOGIC_VECTOR (15 DOWNTO 0); signal period_hr_register: STD_LOGIC_VECTOR (15 DOWNTO 0); signal period_l_wr_strobe: STD_LOGIC_VECTOR (15 DOWNTO 0); signal read_mux_out: STD_LOGIC_VECTOR (15 DOWNTO 0); signal snap_hr_strobe: STD_LOGIC; signal snap_hr_strobe: STD_LOGIC; signal snap_textrobe: STD_LOGIC; signal snap_strobe: STD_LOGIC; signal start_strobe: timeout_occurred: STD_LOGIC; signal timeout_occurred: STD_LOGIC; signal timeout_occurred: STD_LOGIC; begin clk_en <= std_logic'('1'); process (clk, reset_n) begin if reset_n = '0' then internal_counter <= std_logic_vector'("0000000000000000001100001101001"); elsif clk'event and clk = '1' then if std_logic'((counter_is_running OR force_reload)) = '1' then if std_logic'((counter_is_zero OR force_reload)) = '1' then internal_counter <= counter_load_value; else</pre> else internal_counter <= A_EXT (((std_logic_vector'("0") & (internal_counter)) - std_logic_vector'("000000000000000000000000001")), 32); end if; end if; end if: end process; counter_is_zero <= to_std_logic((internal_counter = std_logic_vector'("0000000000000000000000000000000))); counter_load_value <= period_h_register & period_l_register; process (clk, reset_n)</pre> begin begin if reset_n = '0' then force_reload <= std_logic'('0'); elsif clk'event and clk = '1' then if std_logic'(clk_en) = '1' then force_reload <= period_h_wr_strobe OR period_l_wr_strobe;</pre> end if; end if; end process; do_start_counter <= start_strobe; do_stop_counter <= ((stop_strobe) OR (force_reload)) OR ((counter_is_zero AND NOT control_continuous)); process (clk, reset_n)</pre> hegin begin if reset_n = '0' then counter_is_running <= std_logic'('0'); elsif clk'event and clk = '1' then if std_logic'(clk_en) = '1' then if std_logic'(do_start_counter) = '1' then counter_is_running <= Vector_To_std_Logic (-SIGNED (std_logic_vector'("0000000000000000000000000000000000)))); elsif std_logic'(do_stop_counter) = '1' then counter_is_running <= std_logic'('0'); end if:</pre> end if; end if; end if; end process; -delayed_unxcounter_is_zeroxx0, which is an e_register process (clk, reset_n) begin if reset_n = '0' then delayed_unxcounter_is_zeroxx0 <= std_logic'('0'); elsif clk'event and clk = '1' then if std_logic'(clk_en) = '1' then delayed_unxcounter_is_zeroxx0 <= counter_is_zero; end if;</pre> timeout_event <= (counter_is_zero) AND NOT (delayed_unxcounter_is_zeroxx0); process (clk, reset_n)</pre> ``` ``` if reset_n = '0' then timeout_occurred <= std_logic'('0'); elsif clk'event and clk = '1' then if std_logic'(clk_en) = '1' then if std_logic'(status_wr_strobe) = '1' then</pre> timeout_cocurred <- std_logic'('0'); elsif std_logic'(timeout_event) = '1' then timeout_ocurred <- Vector_To_Std_Logic (-SIGNED(std_logic_vector'("000000000000000000000000000000)))); end if; end process; & A ToStdLogicVector(timeout occurred)))))); process (clk, reset_n) process (cik, reset_n) begin if reset_n = '0' then readdata <= std_logic_vector'("0000000000000000"); elsif clk'event and clk = '1' then if std_logic'(clk_en) = '1' then roaddata <- read mux out;</pre> readdata <= read_mux_out; end if; end if; end process; if reset_n = '0' then 11 reset_n = '0' then period_l_register <= std_logic_vector'("0001100001101001"); elsif clk'event and clk = '1' then if std_logic'(period_l_wr_strobe) = '1' then period_l_register <= writedata; end if; end if;</pre> end process; process (clk, reset_n) begin begin if reset_n = '0' then period_h_register <= std_logic_vector'("0000000000000000"); elsif clk'event and clk = '1' then if std_logic'(period_h_wr_strobe) = '1' then period_h_register <= writedata;</pre> end if; end if: end process; end process; ``` #### timer.vhdl ``` library ieee; use ieee.std_logic_l164.all; use ieee.numeric_std_all; entity timer is port ( clk: in std_logic; read: in std_logic; read: in std_logic; write: in std_logic; write: in std_logic; chipselect: in std_logic; chipselect: in unsigned(15 downto 0); readdata: out unsigned(15 downto 0); writedata: in unsigned(15 downto 0) ); end timer; architecture rtl of timer is signal we,wl,wh,ws: std_logic; signal lo: unsigned(15 downto 0); signal hi: unsigned(15 downto 0); signal a : unsigned(15 downto 0); signal v: re:std_logic; signal re:std_logic; signal re:std_logic; signal re:std_logic; signal re:std_logic; signal v: unsigned(15 downto 0); signal v: unsigned(15 downto 0); signal v: unsigned(15 downto 0); signal v: unsigned(15 downto 0) = lse '0'; whome vi' when we '1' and address = "00000" else '0'; whome vi' when we '1' and address = "00000" else '0'; whome vi' when we '1' and address = "00000" else '0'; re (v')' when we '1' and address = "00000" else '0'; re (v')' when we '1' and address = "00000" else '0'; re (v')' when we '1' and address = "00000" and re -'1' else valid downto 16) when address="00000" and re -'1' else valid downto 16) when address="00000" and re -'1' else valid downto 16) when address="00000" and re -'1' else valid downto 16) when address="00000" and re -'1' else valid downto 16) when address="00000" and re -'1' else valid downto 16) when address="00000" and re -'1' else valid downto 16) when address="00000" and re -'1' else valid downto 16) when address="00000" and re -'1' else valid downto 16) when address="00000" and re -'1' else valid downto 16) when address="00000" and re -'1' else valid downto 16) when address="00000" and re -'1' else valid downto 16) when address="00000" and re -'1' else valid downto 16) when address="00000" and re -'1' else valid downto 16 ``` ``` else va <= va - 1, end if; end if; end if; end if; end process;</pre> ``` ### timer\_hw.tcl ``` # Tot Five Selected by Component Editor 7.2 on: * Toe Nay 2 5 19:56:46 EDT 2012 ** Toe Nay 2 5 19:56:46 EDT 2012 **set_pounce_file "timer, void" void, void" **set_pounce_file "timer, void, ``` ### timer\_inst.vhd ``` -Legal Notice: (C)2007 Altera Corporation. All rights reserved. Your -use of Altera Corporation's design tools, logic functions and other -software and tools, and its AMPP partner logic functions, and any -output files any of the foregoing (including device programming or -simulation files), and any associated documentation or information are -expressly subject to the terms and conditions of the Altera Program -license Subscription Agreement or other applicable license agreement, -including, without limitation, that your use is for the sole purpose ``` ``` -of programming logic devices manufactured by Altera and sold by Altera -or its authorized distributors. Please refer to the applicable -agreement for further details. - turn off superfluous VHDL processor warnings - altera message_level Level1 - altera message_off 10034 10035 10036 10037 10230 10240 10030 library altera; use altera.altera_europa_support_lib.all; library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_arith.all; use ieee.std_logic_unsigned.all; entity timer_inst is port ( -inputs: signal address : IN STD_LOGIC_VECTOR (2 DOWNTO 0); signal chipselect : IN STD_LOGIC; signal ck : IN STD_LOGIC; signal write n : IN STD_LOGIC; signal writedata : IN STD_LOGIC_VECTOR (15 DOWNTO 0); - outputs: signal irq : OUT STD_LOGIC; signal readdata : OUT STD_LOGIC_VECTOR (15 DOWNTO 0) ... end entity timer_inst; architecture europa of timer_inst is component timer is port ( - inputs: - inputs: signal address : IN STD_LOGIC_VECTOR (2 DOWNTO 0); signal chipselect : IN STD_LOGIC; signal clk : IN STD_LOGIC; signal writen : IN STD_LOGIC; signal writedata : IN STD_LOGIC, - outputs: signal irq : OUT STD_LOGIC; signal readdata : OUT STD_LOGIC_VECTOR (15 DOWNTO 0) end component timer; signal internal_irq : STD_LOGIC; signal internal_readdata : STD_LOGIC_VECTOR (15 DOWNTO 0); -the_timer, which is an e_instance the_timer: timer port map( irq => internal_irq, readdata => internal_readdata, address => address, chipselect => chipselect, clk => clk, write_n => write_n, writedata => writedata ); -vhdl renameroo for output signals irq <= internal_irq; -vhdl renameroo for output signals readdata <= internal_readdata; end europa; ``` 95