Log inRegister an accountBrowse CSDbHelp & documentationFacts & StatisticsThe forumsAvailable RSS-feeds on CSDbSupport CSDb Commodore 64 Scene Database
You are not logged in - nap
CSDb User Forums


Forums > CSDb Entries > Release id #209983 : cc1541 V3.3
2021-10-05 04:55
Zaphod

Registered: Jun 2012
Posts: 63
Release id #209983 : cc1541 V3.3

A tip. If you use -r to specify a start track, if said track is before 18 and you are using transwarp, it will go backwards instead of forwards. This behavior makes sense, but it is probably not what you would expect.

Transwarp can only use consecutive empty tracks . So you may run into the track 18 barrier when trying to add a file. Changing the order or starting track of files will help get around this.
2021-10-05 10:04
Krill

Registered: Apr 2002
Posts: 2982
And when putting multiple Transwarp files on a previously empty image, how many of them fit depends on their order. This is because Transwarp files occupy entire tracks, and there are 4 different track sizes across the disk.

I briefly thought about some kind of detection/recommendation routine for minimal Transwarp file sizes across a disk, but didn't find anything that would not naively try all permutations on the files' order. But the number of permutations grows fast... It's almost like the bin-packing problem with its NP-hardness maps directly to this problem. =)
2021-10-06 09:02
JackAsser

Registered: Jun 2002
Posts: 2014
Quote: And when putting multiple Transwarp files on a previously empty image, how many of them fit depends on their order. This is because Transwarp files occupy entire tracks, and there are 4 different track sizes across the disk.

I briefly thought about some kind of detection/recommendation routine for minimal Transwarp file sizes across a disk, but didn't find anything that would not naively try all permutations on the files' order. But the number of permutations grows fast... It's almost like the bin-packing problem with its NP-hardness maps directly to this problem. =)


OT: It's exactly bin-packing. I did a fit big bins first for my auto memory layout in EotB. It basically parses all the .lib and .o files emitted from CA65 to find all segments and segment sizes. It then places them in the 64 memory segments defined for the EotB-cart. This method freed up around 60kb worth of ROM and made a nice consecutive free area at the end of the cart.

That said, even a simple naive approach like mine is worth it. It doesn't have to be optimal (I.e. NP complete).
2021-10-06 14:31
Krill

Registered: Apr 2002
Posts: 2982
Ah, i secretly hoped to trigger you. =)

Quoting JackAsser
OT: It's exactly bin-packing. I did a fit big bins first
Not so sure how exactly it's exactly that. =)

If you assume 4 bins (tracks 1-17, 20-24*, 25-30 and 31-35), then only the big bin (tracks 1-17) is a real bin w/r/t the bin-packing problem.
Items in the other bins may spill over to the next higher bin, and may change size (number of occupied tracks) depending on what adjacent part of them goes to which successive bin.

Quoting JackAsser
That said, even a simple naive approach like mine is worth it. It doesn't have to be optimal (I.e. NP complete).
It appears that a few random or semi-random shuffles performed by the user are sufficient to find a good-enough solution. It could pack the showcase images densely enough (all 33 available tracks used) with relatively little effort and without an automated solution.

* Tracks 18 and 19 are occupied by directory and boot stub.
2021-10-07 18:57
Zaphod

Registered: Jun 2012
Posts: 63
There are a few conflicting principles, in no particular order.

1) larger files should go in the bigger bin, cause they will load faster from there.
2) files should go in the bin that wastes the least space. This sometimes conflicts badly with number 1. this fits the greatest amount of data.
3) files should start as close to the directory track as possible, to minimize head seek times. this can conflict with 1, 2, or both.
4) smaller files in the same bin should be closer than larger files. this minimzes the maximum seek time.
5) if the order of loading is known, total seek time should be minimized. this can override number 4.

so actually a fairly complex problem to eke out every bit of speed. if storage space is the issue, though you don't need to try too much. then again, you are using transwarp for speed, not to maximize storage. :)

The real solution is a gui mastering program that lets peopl drag and drop transwarp files ono the disk. :)
2021-10-07 20:15
Krill

Registered: Apr 2002
Posts: 2982
Quoting Zaphod
There are a few conflicting principles
Indeed. But i guess the user can be trusted to use the -r ("restrict") option to specify a starting track. (Granted, with a bit of trial and error.)
2021-10-07 22:22
Claus_2015

Registered: Oct 2012
Posts: 53
If speed is the most important factor, I think the main driving factor is clearly how often each file will be accessed. In a multi load game, there will always be certain files that only need to be accessed once during startup, while others are required more often.

I actually thought about giving priorities to files in cc1541 in the past, to decide where to place them on the disk. But in the end it seemed a complicated thing to handle by the user, with only a minor benefit.
2021-10-08 01:45
Zaphod

Registered: Jun 2012
Posts: 63
There have been cases where i've had to use -r because the default is not optimal, though it's a greater issue when you need to work around preallocated blocks.

Koronis Rift was a nightmare in that regard, but i did it.

still should be some note that for transwarp, -r is the highest track if below 18, and the lowest track if above 18.
2021-10-08 14:45
Krill

Registered: Apr 2002
Posts: 2982
Quoting Zaphod
If you use -r to specify a start track, if said track is before 18 and you are using transwarp, it will go backwards instead of forwards. This behavior makes sense, but it is probably not what you would expect.

Quoting Zaphod
still should be some note that for transwarp, -r is the highest track if below 18, and the lowest track if above 18.
The note would be something in the vein of

"While cc1541 optimises for sequential loading of files or a directory buffer, and thus allocates standard-format files from track 1 upwards, Transwarp files are allocated like standard-format files allocated by the original CBM DOS.
I.e., starting from around the directory track and then away from the directory track.
Note that Transwarp files occupy contiguous chunks of entire tracks, and thus may not be split across the directory track or tracks occupied any other files."
2021-10-08 14:54
Krill

Registered: Apr 2002
Posts: 2982
Quoting Zaphod
The real solution is a gui mastering program that lets peopl drag and drop transwarp files ono the disk. :)
Since the encoder is released under cc1541's permissive MIT-style license (while the C-64/drive-side 6502 assembly decoder/loader code is GPL-licensed), somebody may some day build just such a tool. =)
2021-10-08 15:51
Claus_2015

Registered: Oct 2012
Posts: 53
The point will come, when the commandline help of cc1541 just is not sufficient anymore and real documentation will be needed. Well, I feel that point was actually already reached some years ago :-D.
2021-10-08 16:39
chatGPZ

Registered: Dec 2001
Posts: 11391
$ x64sc -help | wc -l
1816


*evil laughter*
2021-10-08 17:39
Frantic

Registered: Mar 2003
Posts: 1648
*nerdy evil laughter*
2021-10-08 18:16
tlr

Registered: Sep 2003
Posts: 1791
https://www.youtube.com/watch?v=g20_8-TPyTQ
2021-10-08 18:36
JackAsser

Registered: Jun 2002
Posts: 2014
Quote:
$ x64sc -help | wc -l
1816


*evil laughter*


2>&1
2021-10-08 18:46
Zaphod

Registered: Jun 2012
Posts: 63
Quote:

-r track Restrict next file blocks to the specified track or higher.

it doesn't do that for transwarp, unless said track is higher than 19

i went "i said lowest track of 7, why is it trying to write to 6?!?!"

so where's decc1541? (extracts files from existing .d64 and .g64 images, including vorpal/heureka sprint/rapidlok/v-max/etc.) :)
2021-10-09 03:37
Krill

Registered: Apr 2002
Posts: 2982
Quoting Zaphod
Quote:

-r track Restrict next file blocks to the specified track or higher.

it doesn't do that for transwarp, unless said track is higher than 19

i went "i said lowest track of 7, why is it trying to write to 6?!?!"
Yeah, well, the documentation isn't updated yet, as the priority was on releasing the functionality itself.

Quoting Zaphod
so where's decc1541? (extracts files from existing .d64 and .g64 images, including vorpal/heureka sprint/rapidlok/v-max/etc.) :)
Feel free, go ahead and make it real! =)
RefreshSubscribe to this thread:

You need to be logged in to post in the forum.

Search the forum:
Search   for   in  
All times are CET.
Search CSDb
Advanced
Users Online
Mike
iAN CooG/HVSC
GuyGavin/HF
JLD/Finnish Gold
icon/The Silents, Sp..
WVL/Xenon
Guests online: 128
Top Demos
1 Next Level  (9.7)
2 13:37  (9.7)
3 Coma Light 13  (9.6)
4 Edge of Disgrace  (9.6)
5 Mojo  (9.6)
6 Uncensored  (9.6)
7 The Demo Coder  (9.6)
8 Comaland 100%  (9.6)
9 What Is The Matrix 2  (9.6)
10 Unboxed  (9.6)
Top onefile Demos
1 Layers  (9.7)
2 Cubic Dream  (9.6)
3 Party Elk 2  (9.6)
4 Copper Booze  (9.6)
5 Dawnfall V1.1  (9.5)
6 Rainbow Connection  (9.5)
7 Morph  (9.5)
8 Libertongo  (9.5)
9 Onscreen 5k  (9.5)
10 It's More Fun to Com..  (9.5)
Top Groups
1 Booze Design  (9.3)
2 Oxyron  (9.3)
3 Performers  (9.3)
4 Triad  (9.3)
5 Censor Design  (9.3)
Top Logo Graphicians
1 t0m3000  (10)
2 Sander  (9.8)
3 Mermaid  (9.5)
4 Shine  (9.4)
5 Pal  (9.4)

Home - Disclaimer
Copyright © No Name 2001-2025
Page generated in: 0.059 sec.