Home Technical Talk

RT CASS Source

Just read this PDF

Real-Time Creased Approximate Subdivision Surfaces seems to be one awesome technique to achieve super-smooth Models. Not sure if any engine can yet handle this stuff but the approach how they implented this into Source (yet not public though -.-) sounds rather good and performant. Microsoft is going to build this into DirectX11, they won't like the fact they showed you can do this in DirectX9 with no problems :D

Replies

  • fearian
    Options
    Offline / Send Message
    fearian greentooth
    Soo... is this turbosmooth without the need to have reinfoced edge loops all over the place?

    I am clueless :(
  • MoP
    Options
    Offline / Send Message
    MoP polycounter lvl 18
    question is, would this technique be faster than just modelling a more detailed mesh? :)

    also, is it worth the effort of having to model using a completely different set of techniques for something that will only look correct in one particular method of rendering?

    interesting stuff, but i don't really see this catching on for games. reminds me of that "truform" subdivision stuff ATI did a while back, basically subdivision in realtime, but it meant you had to model stuff specifically with that technique in mind, and i think partly because of that, it never caught on.
  • e-freak
    Options
    Offline / Send Message
    No the only two factors you've got to keep in mind here is modelling with quads (to allow the engine to look for edgeloops) and mark seems (just as in uv layouting) to allow the render to break loops there. Afaik the trick is it will work out beziers then which will not only smooth the models lighting but will remove any edge on the silouette as well. Look at that Heavy's face or Hand. Of course you can just increase the polycount on such a model but that would cost more performence and zooming in on details, edges would remain.

    25767seou.jpg
    257685jju.jpg
  • rebb
    Options
    Offline / Send Message
    rebb polycounter lvl 17
    I haven't read the PDF yet, but it looks a lot like "Edge-Creasing" in Maya or the Edge-Weight in Modo .
  • MoP
    Options
    Offline / Send Message
    MoP polycounter lvl 18
    Yeah, it's already available in Max, Maya, Modo and pretty much every app, and I know exactly how it works and what workflow you'd use, e-freak ... however I still don't believe it will catch on for in-game use. It's just too specific and nothing else uses that method, and I don't think it will become the new standard.
  • Neox
    Options
    Offline / Send Message
    Neox godlike master sticky
    Didn't ati already have such things years ago working on their cards with a special driver? sucked seeing the lowpoly meshes beeing destroyed with it. i don't know maybe it's usefull for sequences as Valve did it there but the ingame models still look better to me, the heavies face is looking pretty meshsmoothed there :/
  • e-freak
    Options
    Offline / Send Message
    well it's going to be the new standard as it will be an essential part of directx 11, valve and the ny university just proved it to be perfectly possible in directx9 and realtime. every major app in prerendering has this - but no realtime engine could handle this yet so the approach is pretty cool imho.

    yeah ati used a tesselation module years ago but all it did was ruining lowpoly models - i remember playing half-life with it and the guns started looking like micky mouse.
  • MoP
    Options
    Offline / Send Message
    MoP polycounter lvl 18
    heh, we'll see if it becomes the new standard or not, i guess. i'm still not entirely sure why you're so confident everyone will adopt this.
  • JohnnyRaptor
    Options
    Offline / Send Message
    JohnnyRaptor polycounter lvl 15
  • e-freak
    Options
    Offline / Send Message
    MoP - there are two ways to increase graphical quality on game models (apart from good craftmansship):

    a) Increase number of polygons until number of edges limits infinite (pytagoral approximation of the circle)
    b) Develop such Algorithms that will create mathematical functions (Beziers) for given points (Function defined by given coordinates, math lessons in 10th grade at school).

    While point A is the approach until today it comes to a limit already. You would need to get away from rastarization renders to raytracing renders because the number of polygons uses equates roughly the factor the usual rastariazation runs slower, while the number of polygons used in a raytracing scene doesn't matter (it does but the factor is infinite times lower than in rastarization graphics). It's higly unlikely nvidia or ati are going to invest billions into new raytracing technology (actually they are researching this but until now realtime systems with raytracing tend to be too slow, see OpenRT, QuakeRT and simmilars) so they gonna look for other technologies.

    So if a) is not an option for long now, it becomes clear that b) will be the solution of choice.
  • Neox
    Options
    Offline / Send Message
    Neox godlike master sticky
    The problem is that infinite smoothing isn't making the assets better it's just making them rounder, what do you want an ubersmooth always round silhouette for? Walk on a characters face and see no edges?
    Normally a developer should know what his characters are made for and therefore create the asset, if you never see the face upclose why put in thousands of tris there?
    It's just like automated performance waste, sure if it doesn't matter why not do it, but it only works for clean surfaces, what dou you want to do with it on a realistic character?
    it can't get more detailled then the initial model, just rounder and texturespace is already more the bottleneck then polygons, displacing this surface would still need textures to displace from and the won't stay as detailled unless you go with fractals and such things to randomize the details on a macro level.
  • MoP
    Options
    Offline / Send Message
    MoP polycounter lvl 18
    Also, it's worth thinking about how this would work on something like one of the giant monsters or mutants from a game like Doom3 for example - those things are not smooth curves separated by sharp edges, in fact it'd be a nightmare (pun unintended) to try and model something like a Doom3 demon zombie creature using these creases and subdivision surfaces - just try it, it'll either look rubbish or take ten times longer than usual to make because you're trying to manage all the creasing.
    Something like ZBrush is far more suited to this kind of work, and as a result it's going to be far more likely to get a good look by just throwing lots of polygons at it - in mudbox or zbrush you don't even have to think about polys, you just sculpt... whereas this crease stuff is really not artist-friendly, it would take a LOT of management and technical awareness to make it work and look good. Again another reason why it will not catch on in general.

    The only thing I can see this technique really being used for is stuff like racing games or simulators where stuff like the car models need to be really smooth and detailed, and can actually get away with having the "ultra sharp" lines that creasing produces. I can maybe see it catching on for stuff like that.

    It's also possible that stylised stuff like TF2 might make use of it, but again that's a very limited scenario and only works for certain things.

    Again I really don't see it catching on for the whole industry just because it's something that only works in really specific scenarios and visual styles.
  • e-freak
    Options
    Offline / Send Message
    Well normal-mapping still applies on these models, and afaik the doom 3 monsters were just lowpoly figures with heavy normal maps on them. sure they could have benefited from this technology as well.

    doom3.jpg

    the back is supposed to be round but the silouette clearly gives away the lack of polys.
  • CrazyButcher
    Options
    Offline / Send Message
    CrazyButcher polycounter lvl 18
    there is no question that the race is on, about keeping the detail that already exists in production for the game. However what technique at the end will "win", I think, isn't clear yet. Imo we will see less standard pipeline in future, and more customized rendering pipes with the advancement of many-core systems (GPGPU whatever).

    What kind of technique (ie standard rasterizer with tessalation, real-time reyes rendering or other funky stuff, voxel sampling..) will become standard (or if any) is "unsure" imo.

    My personal feeling is that the top engine makers will try to cook their own soup. And hints by id & epic make me think they will.

    The platform that will decide is the "next" generation of consoles due in 2012 or whenever. And when you think about cost cutting and current trend, I would assume it will be something like PS3 was originally meant to be (ie just Cell, no graphics card). Reason is intel is trying to push its many-core pseudo graphics card (larrabee), nvidia and ati will generalize their graphics card even more. The Geforce GTX 3xx coming end of year is rumored to be quite another big jump in architecture (from SIMD to MIMD) and would allow more customized rendering.

    with dx9 still dominating I also fail to see dx11 make a big difference here, surely it brings the stuff that was supposed to happen with dx10 (geometry shader can do tessalation, just not performant enough, so we get other shaders now to make it useful...)

    in the long run I think we will get back to "software" rendering days, just that this time the hardware can do much more. This is much better in terms of performance per watt and cost cutting (ie have one central cpu that can do "more" and then many specialized chips that do any form of number crunching tasks)
Sign In or Register to comment.