Adding to Cart…
Licensing Agreement | Terms of Service | Privacy Policy | EULA
© 2025 Daz Productions Inc. All Rights Reserved.You currently have no notifications.
Licensing Agreement | Terms of Service | Privacy Policy | EULA
© 2025 Daz Productions Inc. All Rights Reserved.
Comments
@Padone Does the import script not use the material id as the material's name, and hence the material slot's name?
I have too many issues just rendering anything in Blender right now so haven't been but when I sort that out looking forward to this
(its not wanting to use my graphics card)
I can wait. I'm sure we all appreciate the efforts you techie wizards are making towards interoperability. If you had one of those buy-me-a-coffee links I'd buy you one.
Yeah, much appreciation to people out there coding this stuff.
Yeah, I know. I'm not quite the Blender evangelist yet but you guys are making it possible for me to become one. I still have so much to learn but then I'm still learning new things about DAZ Studio and I've been playing with it for 15 years. I'm between projects right now - that sounds grand and professional but I am just a hobbyist and the "projects" are my personal follies but they keep my creative juices flowing - so I spending more time watching Blender tutorials.
First, I would like to understand your planned workflow on how Diffeomorphic's material script is applied to Alembic imported objects.
Are you making changes to Diffeomorphic scripts so that the material creation scripts can be applied?
Or are you importing a .duf file via Diffemorphic and using your own custom script to copy over materials?
Or something else?
I'm having trouble seeing why not simply infer the material id from material script within blender.
The .duf files may look small but they are gzipped. So if you extract it, they can be 10x the size.
i.e. a single Victoria 8 with full Samurai outfit is ~9MB in raw DSON file vs 595KB as gzipped .duf file
And for large scenes, I can only imagine how big the raw DSON file will be. (100MB? possible)
I can see DSON parsing within Alembic exporter definitely slowing down the export speed noticeably
duplicate post deleted
yeah both my 980ti and onboard Vega graphics show, it did work at some stage but a Nvidia driver update or so ago it stopped working
If I can duplicate Diffeo's reckoning of materials, no script will be necessary. Since the material slot names will all be the same for both both import methods, simply importing the Diffeo model and then importing the Alembic model will have them all applied correctly to the Alembic model.
This won't be necessary. The only missing piece is how to name the Alembic surfaces after the id of the material on that surface. This information is in the DSON.
I'm parsing the duf file as well, because Diffeo has access to the unique material IDs it uses to name the materials, but the C++ SDK does not seem to. So I think it'll be easiest to just get them from the DSON as well.
I don't see how the material ID can be inferred. Can you explain what you mean in more detail? I don't rule out my over-looking something.
I think you are basing your estimate on python or javascript? JsonCpp parses my 28MB unzipped test file in 1.056 seconds.
Let me know.
Okay, I've done a quick bench on another duf file. (3 figures and a scene) which translates to 39MB unzipped
This was done using Rust's serde_json, which is apparently faster than the fastest cpp json parser https://users.rust-lang.org/t/serde-and-serde-json-1-0-0-released/10466/5
Takes up to 0.3 second to unzip and parse the JSON to structs.
But this is using Threadripper 3960x.
I still would prefer to avoid parsing DSON within Alembic, because this is doubling the DSON parsing time from end user's perspective (first from Alembic, second from Diffeomorphic/Z-Cycle's material parser)
So that 0.3 second doubles to 0.6 in the best case. And could increase to 1+ second for even larger scenes.
For some ppl, that may not be a big deal.
But for the following use case - click two buttons, one from daz, other from blender, in order to sync Daz scene to Blender and start render manually by user as soon as possible
That may turn out to be just long enough to add to the annoyance of export&import processing time.
Other alternatives on importing Alembic file and applying Diffeomorphic mats:
It's up to you at the end, but the above are my recommendations
And I'm grateful for them. I'm just barely beginning to understand Daz materials.
It's essentially the script that I have now, that harvests the Diffeo materials and creates normalized names of the form collection.object.material, removing any numbering. This way, a second script that obeys the same normalization rule knows what material to put where, even if Alembic material slots are missing because they were ignored, or in a different order. I just wasn't clear on how/why material IDs get renumbered in order to stay unique and could not convince myself that normalizing the material slots names in that way would never lose information. Is the material ID that Diffeo uses always of the form daz_surface-n? Give me some time to see that this is the case.
But an advantage of doing the parsing is that if the material slot names on both imports are preceisely equal, there are no additional texturing steps after importing. The parsing is easy enough to at least make it an option.
Thanks for your collaboration.
@JClave
So, parsing the DSON is simple, clear and straightforward. It provides a rock solid mapping of a node's surfaces to the material ID's used by Diffeo. This would enable the Alembic exporter to do all the work, without any scripts 0.861 seconds on a 1950X.
While I do feel good about that, it also shows that you are also correct; there are no cases where the surface name is not simply the material ID with the numbering removed. I'll try it on a more complex duf and see if I can invalidate the assumption, but it looks good from here.
If you are concerned about the time, both implementations are easy, so I'll do both.
We are kicking some serious butt... I don't want to go to work tomorrow :)
ripper:~ $ time ./json
==============================================
MATERIAL INSTANCES
==============================================
geometry_id: #KaftanLongA surface: Kaftan material_id: Kaftan-1
geometry_id: #Lashes surface: EyeMoisture material_id: EyeMoisture-3
geometry_id: #Lashes surface: Eyelashes material_id: Eyelashes-1
geometry_id: #aprilyshKarissaHairG8F surface: hair1 material_id: hair1-1
geometry_id: #aprilyshKarissaHairG8F surface: hair2 material_id: hair2-1
geometry_id: #aprilyshKarissaHairG8F surface: scalp material_id: scalp-1
geometry_id: #geometry-10 surface: 02___Default material_id: 02___Default-1
geometry_id: #geometry-10 surface: 08___Default material_id: 08___Default-1
geometry_id: #geometry-10 surface: 09___Default material_id: 09___Default-1
geometry_id: #geometry-10 surface: wire_134006006 material_id: wire_134006006-1
geometry_id: #geometry-10 surface: wire_143224087 material_id: wire_143224087-1
geometry_id: #geometry-5 surface: Default material_id: Default-1
geometry_id: #geometry-6 surface: Arms material_id: Arms
geometry_id: #geometry-6 surface: Cornea material_id: Cornea-1
geometry_id: #geometry-6 surface: Ears material_id: Ears
geometry_id: #geometry-6 surface: EyeMoisture material_id: EyeMoisture-2
geometry_id: #geometry-6 surface: EyeSocket material_id: EyeSocket
geometry_id: #geometry-6 surface: Face material_id: Face
geometry_id: #geometry-6 surface: Fingernails material_id: Fingernails
geometry_id: #geometry-6 surface: Irises material_id: Irises
geometry_id: #geometry-6 surface: Legs material_id: Legs
geometry_id: #geometry-6 surface: Lips material_id: Lips
geometry_id: #geometry-6 surface: Mouth material_id: Mouth
geometry_id: #geometry-6 surface: Pupils material_id: Pupils
geometry_id: #geometry-6 surface: Sclera material_id: Sclera
geometry_id: #geometry-6 surface: Teeth material_id: Teeth
geometry_id: #geometry-6 surface: Toenails material_id: Toenails
geometry_id: #geometry-6 surface: Torso material_id: Torso
geometry_id: #geometry-7 surface: 01___Default material_id: 01___Default-2
geometry_id: #geometry-7 surface: 07___Default material_id: 07___Default-2
geometry_id: #geometry-8 surface: 01___Default material_id: 01___Default-3
geometry_id: #geometry-8 surface: 07___Default material_id: 07___Default-3
geometry_id: #geometry-9 surface: material1 material_id: material1-1
geometry_id: #geometry-9 surface: material2 material_id: material2-1
geometry_id: #geometry-9 surface: material3 material_id: material3-1
geometry_id: #geometry-9 surface: material4 material_id: material4-1
geometry_id: #geometry-9 surface: material5 material_id: material5-1
geometry_id: #geometry-9 surface: material6 material_id: material6-1
==============================================
SCENE NODES
==============================================
node: African Headwear
geometry id: geometry-9
geometry URL: #geometry-3
node: Amira
geometry id: geometry-6
geometry URL: /data/DAZ%203D/Genesis%208/Female/Genesis8Female.dsf#geometry
node: Earring Left
geometry id: geometry-7
geometry URL: #geometry-1
node: Earring Right
geometry id: geometry-8
geometry URL: #geometry-2
node: Genesis 8 Female Eyelashes
geometry id: Lashes
geometry URL: /data/DAZ%203D/Genesis%208/Female%20Eyelashes/Genesis8FemaleEyelashes.dsf#Lashes
node: Head Jewelry
geometry id: geometry-10
geometry URL: #geometry-4
node: KaftanLong
geometry id: KaftanLongA
geometry URL: /data/Nikisatez/G8FKaftans/dForce%20Kaftan%20Long/KaftanLongA_20958.dsf#KaftanLongA-1
node: Karissa Hair Genesis 8 Female
geometry id: aprilyshKarissaHairG8F
geometry URL: /data/AprilYSH/KarissaGenesis/KarissaHairG8F/aprilyshKarissaHairG8F_174239.dsf#aprilyshKarissaHairG8F
node: Plane
geometry id: geometry-5
geometry URL: #geometry
real 0m0.861s
user 0m0.723s
sys 0m0.136s
I'm not sure since this is specific to the hd exporter. I mean the standard exporter doesn't export material names. I guess this is useful to Thomas to link the hd materials.
As for the material names for the alembic file, I have a different opinion and I don't like the "normalizer" script idea. I mean if you get the ids from the duf file then it's already done as you reported yourself, and the procedure would be simply:
1. export alembic
2. import diffeo
3. import alembic and the materials are automatically applied since they share the ids
I don't see how gaining a couple of seconds to avoid parsing the duf file can benefit the user in any way since then we'd have to launch an extra script so I fail to understand the point by @JClave. But that of course is very minor everything will do as far as it works.
edit. Added a reference to this discussion at diffeomorphic just in case anyone could be interested.
https://bitbucket.org/Diffeomorphic/import_daz/issues/53/
If you do implement both approaches we discussed, that would be fantastic. :)
You do raise a good point about whether material id naming is always formatted like {material name}-{number}
So far, the namings inspected in sample files seem to behave this way. But more research may be needed to eliminate all unknowns with this material inferring approach. (I can think of a possible approach but it's getting to be a bit too much effort to explain. Since I'm probably the only one interested with this approach, I will save explaination for later hah)
@Padone
I think a split second load time increase may be negligible for Blender users who want to do everything in Blender (posing, material tweaking, etc..)
Because they only have to import the same scene once.
But there is also a use case for users who want to do posing and material tweaking in Daz instead. And use Blender as simply an render engine.
(I'm working on Iray Uber Node in Blender as we speak, and I can already tell that people will much prefer to modify parameters for this node in Daz instead of Blender)
For those users, they may want to tweak something in Daz, then import to Blender multiple times to iteratively work on their scene.
I believe the Alembic exporter will enable this use case with import speed that is much more tolerable than Diffeomorphic.
If I understand the conversation correctly, I believe that I may be one of those users you speak of.
No, not at all, I have a vested interest in amximizing utility for everyone.
But note that the parsing would only have to be done once, and while testing I also began to appreciate the need for a quicker method, and that is what I envisioned for the not-yet-implemented "Snapshot" button.
And what I really want to do is do away with file formats altogether and talk directly to Blender over a socket or, better yet, shared memory. Push a button and your model appears in Blender. Serializing everything for sockets is oh so 2000s, and Blender's version of Python doesn't support shared memory yet, but since you're rolling a custom build anyway, maybe when we reach a stable point, we can talk about that.
All this blender progress is getting intense lol.
I can happily report that the first of three techniques for re-applying textures in Blender seems to work, and man, it felt good to see the model appear perfectly without having to do anything at all.
There is now an option two use one of three possible methods for naming the material slots: Diffeo mode, DTB mode, and Guess mode.
I'm going to test a little more and file down some rough edges with the GUI, then I'll publish this version an continue working on the other modes.
good to know, I will find your exporter more useful for my animated renders than those other two options
the DTB option uses even more resources and freezes too but the materials applying to yours is definitely a help
I do need to do shorther animations though, my greed was the biggest issue as the abc files obviously end up massive
my use for Blender is largely as a render option anyway, posing there was never important so alembic is the best
Thanks again for your hard work.
I'm looking forward to your latest exporter so I can finish my material parser's id handling logic.
Also appreciate your willingness to cater for minimal latency with 'Express button'
Good point about benchmarking as well.
No problem. It's just better when tools work together.
Maybe this should be moved to the Blender forum now?
It was, but someone moved it out.
Hi guys, I just found this thread and it's amazing how much work is being put into the plugin.
I know this is a long shot but are there any plans for porting this to 3ds Max? Because the same problems exist there as well (with the DAZ store plugin version).