Hey you. In case you haven’t heard, my good friends from grad school founded an educational video game featuring an original Trazer soundtrack. The company is called Lux Science.
Download and play the beta version of the game, here.
Video games and virtual reality are the future of education (in my opinion). If you’re not convinced, read “Ready Player One.” It’s an amazing book about a future dystopia where everyone is in a virtual reality 95% of the time. The only thing preventing total societal collapse is the fact that virtual education is completely free and completely amazing. Once you’ve thrown all the traditional ideas about education out the window, the sky’s the limit.
Anyway, at the beginning of this project, my friend Roman (a co-founder of Lux Science) came to me and said he needed some ambient music for his game. Music that is unobtrusive, chill, dreamy, and loopable. So I made 4 different tracks, for the different moods he needed to convey in the first chapter:
1) Normal ship – calm exploration music
2) Red alert ship – a more anxious exploration music
3) Inside the Holodeck – excited, some-what trippy music
4) Floating around in a space suit around Mars reflecting on past experiences – peaceful dreamy music
It was fun making all of these, but track #4 is where I started to get really excited. Play the video game, and this is the first track you hear. I love it. I decided it was good enough to expand it into a full-blown Trazer track for release outside of the video game. I’m calling the track “Space,” and I hope to release it in the next few weeks.
It’s a special feeling falling in love with your own song, although it’s happened to me countless times by this point. That honeymoon phase with a new track is so ridiculously exciting. Exciting enough that working on it feels effortless. Exciting enough that I feel an urge to listen to it all the freaking time. It’s special. It’s magical.
So here’s a little teaser of the “full” version of Space. With Snapchat filter. I hope you like it as much as I do.
love,
Anthony / Trazer
P.S. Please subscribe on the sidebar so that you get notifications of new blog posts!
Whoever you are, I’m thankful to have you in my life.
Happy Thanksgiving.
In the spirit of Black Friday and consumerism, I launched some Trazer merchandise, available here. In all seriousness, this is a great way to show your support for my music. I am a 100% independent artist, and every little bit helps. And if you post a picture of yourself wearing Trazer swag, I will love you forever.
By the way, let me know if there’s a particular type of Trazer swag that you’d like, and I’ll see what I can do to make it a reality. I’m here for you, after all.
In other news, I’ve decided to start doing more blog posts. I want to be an open book. I want to share the inner workings of my art. I want you to know who I am as person. And I want to know you. Let me know if there are topics you’d like to see, e.g. how I make my music, what’s my inspiration, my background, my deepest darkest fears, etc.
Just a few things. I’m working hard on a bunch of new tracks, and I’m super excited about every single one. I’ve started experimenting going deeper into the genres of ambient, psybient, and psychill. In other words, I’m creating more dreamy and trippy atmospheres to play in. And I love it. Come play with me.
I’m also constantly working on improving my production skills. Since I quit my day job, I’ve been learning at an accelerated rate. Yay. I still have a lot to learn, but my music keeps getting better. I hope you agree.
Also, here’s my cat Bella. The cat trap is working.
Hey! I just uploaded this visualizer (below) to a remix of my song Love. If you want to learn about how I made the visualizer, keep reading.
It was done entirely in Python (my favorite programming language). At a high level, my code basically creates (from scratch) a whole bunch of images and then compiles them into a video with 30 images (or frames) per second. So how do I make a single frame?
When you look at a color image on a computer, each pixel is typically represented by 3 numbers. Those 3 numbers are the brightness in each of the 3 color channels RED, GREEN, BLUE (or simply RGB). Let’s say those brightness levels can vary anywhere from 0 to 1 (they actually go from 0 to 255 but let’s just use 0 to 1 for simplicity). Using different RGB combinations you can make essentially any color. For example, pure blue is [0,0,1], darker blue is [0,0,0.4], red is [1,0,0], yellow is [1,1,0], magenta is [1,0,1], purple is [0.5,0,1], white is [1,1,1], black is [0,0,0], etc. If you want to play around with RGB coloring, check out this link.
Ok, so the first step in making a frame is to set those RGB values for each pixel in the image. To do this, I first need to understand how to define each pixel’s location. For a single frame, pretend it’s actually an X-Y plot, where the (0,0) point is the bottom left, and each pixel’s location can be defined in (X,Y) coordinates. So for a 1000×1000 pixel image, for instance, the top right pixel is located at (1000,1000) and the center pixel is at (500,500).
To make the colors vary across the image, I define each RGB channel intensity as a function of X and Y in the frame. What’s particularly useful in this case is the fact that the 3 RGB channels are independent, so I can set up 3 different equations (1 for each RGB channel) that define the coloring. To make the color vary in a wave-like manner, these equations need to be sine waves. Something like R=sin(AX+BY/2). The width (or wavelength) of these color bands/stripes can be varied by playing around with those A and B constants. I chose to use different wavelengths for each RGB channel so that they end up mixing in interesting ways.
For instance, if a red stripe crosses paths with a blue stripe, what you see in the overlapping region is purple. So, while the RGB channels are defined independently, what your eye actually sees is a mix of all of them. That’s what creates the huge range of constantly morphing colors, rather than simply red, green, and blue. Super beautiful.
Once those RGB equations were defined, I wanted to give the image that cool symmetry. This step was the hardest part to program. To do this, I first erased everything except 1/8th of the image (cut like a slice of pizza). This is the repeating pattern. Imagine taking a single slice of pizza, and flipping it along one side edge so that it’s now face-down in the neighboring spot. Do it again, and now it’s face-up in the next spot. Keep doing that until you go all the way around and you’re back to where you started. That’s what I did, in a nutshell. It means that each 1/8th slice is a mirror image of it’s neighbors. And that’s what gives you that trippy kaleidoscopic effect.
OK, so now we have one full image. To make the whole video look like it’s moving, each frame needs to vary slightly from the frame before it. This was done by including a “time” variable, t, in the RGB vs. XY functions. Something like R=sin(tAX+BY/2). Each time a new frame is rendered, the equation describing the colors is a tiny bit different because t is increasing. It also causes the wavelength (the width of the color stripes) to vary in time, which explains why the visualizer appears to keep changing. These changing wavelengths were initially unintended, but once I noticed they were happening I fell in love.
Alright, so now we have a bunch of frames that vary in time. Great. Now, you may have noticed that the visualizer responds to the music. I found some Python code that calculates a fast fourier transform of the song. It’s incredibly complicated, and I don’t fully understand how it works, but the output of that code is the sound “intensity” or “loudness” at each frequency at each time. For instance, when a loud kick drum is happening, the frequencies between 30-100Hz have a high intensity. To make the visualizer respond to the music, I inserted this low frequency intensity into a couple of the equations that define the color bands. It’s a little tricky getting it to respond to the bass and kick drum without making the visualizer too strobey. It’s a balance.
And that’s it! Now I can just run the program and it spits out a video. Follow all that? Do you have any suggestions for improving this visualizer? Do you want even MORE detail? Props to you if you got this far. Thanks for reading.
My next blog post will likely be a more detailed discussion of how I make my music. Would that interest you? Stay tuned 😉
Hey Trazer fans. Big news. Today, I officially quit my day job. My wife and I are moving to San Francisco, where I’ll be pursuing music full time.
The timing couldn’t be more perfect. Four years ago today, my life turned a corner, and I admitted to myself that making music was what I wanted, and needed, to do with my life. And so now I’m finally going to try to make that dream a reality. Because after all,
If not now, then when?
If not me, then who?
I expect the next year or so could go 1 of 2 ways:
1) I’ll use my new-found free time to truly perfect my craft, release a bunch of new music in a relatively short time, possibly get signed to a record label, and/or start doing shows. Then just maybe, Trazer will “take off” and become financially viable. This is obviously the best case scenario (or most delusional, depending on who you ask).
2) I’ll run out of money (I’ll be living is San Francisco, after all), or decide that the financial and/or emotional insecurity of the full-time musician lifestyle isn’t for me. Then I’ll *hopefully* get a tech job in Silicon Valley.
I admit the most realistic scenario is perhaps a combo of 1 and 2. That is, I’ll spend the next year setting the stage for a career in music. Then, I’ll get a job to help pay the bills while pursuing music the rest of the time.
Over the last couple of years, I’ve had the pleasure of receiving messages from people from all over the world. This “fan mail” ranges from simple but expressive YouTube comments, to multi-paragraph emails about how my music has made a positive impact on someone’s life, to extremely generous donations via PayPal (TrazerMusic@gmail.com) or my Bandcamp page. You know who you are, and I thank you from the bottom of my heart. Seriously, thank you.
That brings me to my final point. To all of my fans, I need you. You are the foundation upon which my dream stands. I am nothing without you. So please, if there was ever a time to show your support, it would be now.
You can help out however you feel comfortable. Share or repost my music on social media. Tell your friends. Give me a big hug and tell me everything will be ok. Buy, rate, and review my music on iTunes. Comment on my YouTube videos. Follow me on Facebook, YouTube, Spotify, Twitter, Instagram, etc. I’m not just asking for money, though I am. I’m not just asking for your help in getting my music out into the world, though I am, because I can’t do it alone.
But really, more than anything, I’m asking for your emotional support. If my music speaks to you, simply knowing you exist is a huge source of motivation and inspiration. Please never hesitate to reach out to me.
To those of you who have already shown your support, thank you! You are amazing and inspiring and I love you.
To those of you who think my music isn’t ready for prime time, I agree. I believe in my music, but I acknowledge that I still have a lot to learn. And that’s why I’m doing this, to really sink my teeth into this passion of mine and see how far the rabbit hole goes. If I don’t do it now, I fear that I never will, and I’ll always wonder what could have been.
It’s incredibly scary. Terrifying, to be honest. And yet for the first time in a long while I feel truly optimistic about my future.