r/unrealengine • u/pattyfritters Indie • Nov 17 '24
Just a quick video to show beginners Hard References using Casting and no Hard References using a Blueprint Interface by checking the asset's Reference Viewer. Tutorial
https://streamable.com/myapjv6
u/pattyfritters Indie Nov 17 '24
Here, you can see, I'm trying to communicate between my Player Character Blueprint and a Crafting Table Blueprint. The Cast immediately creates a Hard Reference, meaning that when my player loads into a map, the crafting table and everything it is referencing will also be loaded into memory whether you need it now or not.
3
u/steveuk Nov 18 '24
Also you can cast to a less specialised but common class that doesn't reference a bunch of assets. Generally, the "use interfaces to avoid hard ref" advice gets interpreted as "always use interfaces", even when it's counter-productive to do so.
2
u/Ding-dong-hello Nov 18 '24
Thank you for posting this. Absolutely great advice. Even people working on a AAA games fall for the “you must always use interfaces” or “let’s disable tick, it’s expensive” bit. It’s bs. Optimization is context specific.
1
u/FormerGameDev Nov 19 '24
heh. Currently going through a "disable tick on everything that doesn't need it" optimization pass right now. we're currently down to less than 30 actors ticking on average, when we started this pass, we had 200. We also found several bugs after adding some facilities to debug "what the hell is ticking right now", code that we had no idea was doing some of the things it was doing.
Next project, we're starting with Tick disabled by default on everything, because I am not doing this again. The only things that will have tick enabled will be things that we have proven do not have any other way.
Individual ticks are not expensive, but the combination of all of them can be. In my case, we're in a very physics laden system, and so ticking anything in the world that we are not able to immediately interact with is a detriment.
1
u/Ding-dong-hello Nov 19 '24
Haha I find this hilarious. Starting with tick disabled in everything s how my studio kicked off this project and ended up doing a 180 mid way because it was more pain than gain.
Just be mindful of when you use tick. Use events and slow rolling timers for most everything and ensure you get a code review if tick is touched somewhere. Sometimes tick is simply the right choice though. It’s a tool like any other. It has pros and cons.
2
u/FormerGameDev Nov 19 '24
I normally would not recommend it for most people, doing something like this, but profiling was showing we were blowing a huge amount of cpu ticking, so we built a system that we can display everything in a scene that is ticking ... and we are mostly moving the functionality to other places where it doesn't have to be ticked, as you say. But also, there's a huge amount of stuff that just doesn't need to run at all, things that only need to be ticking when they are being interacted with or relevant. It's an advancement of other systems.
So, not exactly "just stop everything from ticking", but a major pass over "do we need this to even be on? can it be selectively on? can it be ticked less frequently?" and the answer to one of those questions is almost always "yes" for everything in this product.
It's not like we intentionally wrote a bunch of stuff into Tick, but when a lot of your product depends on physics, you're going to be doing a lot of stuff that gets chained into from a Tick somewhere
1
u/Ding-dong-hello Nov 19 '24
Nice one! Yeah by all means, if you profiled and found it to be a problem then adjust accordingly! This is 100% the right way to go about this.
1
u/FormerGameDev Nov 19 '24
i gotta say the part that truly sucks, is being locked to 90 fuckin fps. If you've got to hit 90, you've got to do a lot more ridiculous stuff than other teams lol :-D
1
2
u/d3agl3uk Senior Tech Designer Nov 17 '24
Better yet, use soft references and avoid interfaces altogether.
1
u/OpenSourceGolf Nov 17 '24
Is it because when you use an interface you're doing a cast behind the scenes anyways, but just for the specific parts of the interface that are implemented?
5
u/d3agl3uk Senior Tech Designer Nov 17 '24
Interfaces lean you into putting all of your code into the actor. The result is overally generalised and messy code.
It's far better to use components and lean on composition for systems and logic.
Want to know if the actor has health and do something with it? Get the health component from the actor, and if it has one, deal some damage.This method also removes the need for hard references, and let's your code stay well structured and organised.
1
u/OpenSourceGolf Nov 17 '24
Oh yeah I figured that, I just was guessing that if you used a soft class reference you knew already what you were going to work with as opposed to an interface which could theoretically load a target class you weren't wanting that implemented it
That's mostly what I got from this video for situational approach to whether to use an interface, inherit from a parent class, do an abstract class, or make into a component: https://www.youtube.com/watch?v=tYwN7XPayhE
1
u/Capitan_Tenazas Nov 18 '24
How do you communicate with the component without references? Event Dispatchers? Sorry if the question is on the noob side of things
1
u/lv-426b Nov 17 '24
Super helpful video , I started reducing all my hard references about a month ago. Managed to reduced my memory usage for my hero ship from 16gigs to 500mb.
when I pretend to delete the hero ship is only brings up the widgets I use for consoles which makes sense as they are connected to the ship.
but when I try to migrate the same ship it grabs most of the project to go with it. Any idea why it does that ? Looking at the reference tree , those things aren’t connected. 🤔
2
u/pattyfritters Indie Nov 17 '24
Have you fixed up your redirects? Not sure if that's the problem but if you right click the Content folder and select Fix Up Redirects that might do it?
1
u/Billy-Jack-Medley Nov 17 '24
Interface is the way to go. As soon as I learned about it i wondered how I ever lived without it.
1
u/_sideffect Nov 18 '24
Yup, good vid
People watch these popular unreal youtube videos, and learn completely bad techniques
13
u/nullv Nov 17 '24
This is a great way to demonstrate this. Keep in mind it also applies to things like a DataTable. If you have hard references to assets and objects in a DT you could end up loading into memory a ton of crap you aren't even using.