Jump to content

Recommended Posts

Posted (edited)

Your answer doesn't answer all of my questions, even worst it's the reverse of what you said one post higher.

 

What you highlighted in your first post is the tip of the iceberg, there are a lot of other things to think about : notably AI (both intention AI and event based AI aka scripts), knownlist system (which is atm handled by 11264 L2WorldRegion for IL size map = 22k CHMap, and 1 CHMap per spawn = 45k+ CHMap refreshed every 1,25sec), scripts system. Skill XML engine is the least of your problem (moreover when it actually works exactly as it should).

 

About L2J coding, the whole architecture is pretty much fine, if you do something from scratch, it will look as L2J on the biggest part. You still need a World class, a WorldRegion class, a class which defines Player, etc. 99% of existing variables are needed, few can be cleaned up. 90% of classes are legit (and I would say, based on how L2JFree Genesis and regular Java projects are handled, L2J got like 2x lesser classes that it should - ppl like abstraction so much).

 

Then you got big changes, like... Using a Object oriented database framework, which introduces overhead. Using Netty, which introduces a lot of overhead (from Netty 3 to 4 they divided overhead by 5, just to give you the amount of overhead it creates). Or your reddwarf middleware which is probably also an overhead by itself.

 

More you add external technologies, bigger is the overhead. That's the only point I agree with russians, which developped "commons" package a long time ago.

 

But well, I'm maybe used to L2J. I doubt you can do it easier to understand (in term of organization) with no overhead cost. At least, me, I can't.

 

Moreover, I doubt you will have "time". That's the biggest problem in developpement.

Edited by Tryskell
Posted

So, finally :), AI system and knownlists.

 

I would build a more simplified system for how character AIs and their knownlists are managed.

Also I would definetly not use copy paste retail logic, based on leaked files, I would do what it is expected to be done from a players point of view.

That would help keep it really simplified and optimised.

 

Like a basic character AI that players, npcs and monsters would extend it.

If an NPC or Monster would need something special, I would make a script for it.

Posted (edited)

Go nio-like AIs and tickrate update based servers, that would be a great change

 

LOAD BALANCING ? +++

Edited by xxdem
Posted (edited)

So, finally :), AI system and knownlists.

 

I would build a more simplified system for how character AIs and their knownlists are managed.

Also I would definetly not use copy paste retail logic, based on leaked files, I would do what it is expected to be done from a players point of view.

That would help keep it really simplified and optimised.

 

Politicans speech, "I would make a wonderful world" :D You only speak about theory, reality is different.

 

"NPC AI from player PoV", what does it mean ? You got a NPC who "listens" different types of actions, nothing more.

 

 

Like a basic character AI that players, npcs and monsters would extend it.

If an NPC or Monster would need something special, I would make a script for it.

 

You probably missed entirely the model.ai package, because it's exactly what is it. And next sentence is exactly what L2J is... A specific script for specific case, with the main script being L2AttackableAIScript.

Edited by Tryskell
Posted

You act like you haven't read those scripts.

I took a look at them 2-3 days ago, while I made various code rework on my project.

L2J AIs are "badly" written, following "retail logic" and over-complicating script on many cases.

I would simple choose not to do that on a new project.

 

Take a step further from core AI and see NPC instances.

By todays L2J server scripting potential, they have absolutelly no reason to exist, they may as well have their own script managing them.

From my point of view, its like having two systems doing the same thing.

Posted

Just a pointer on the fact that if we started developing anew things would be more optimised.

Optimization comes with testing. And there is nothing more tested than l2j itself.

Posted

Optimization comes with testing. And there is nothing more tested than l2j itself.

 

You are SO wrong.

Testing equals to things made to work, nothing more.

Run some code coverage plugins on Eclipse and see how much optimised L2J trully is.

 

Also this is not a post on how good L2J is, you get out of the point.

Stick on topic please.

Posted (edited)

You are SO wrong.

Testing equals to things made to work, nothing more.

Run some code coverage plugins on Eclipse and see how much optimised L2J trully is.

 

Also this is not a post on how good L2J is, you get out of the point.

Stick on topic please.

I am sticking on the topic. I am explaining that optimization does come with testing.

If you develop a project using TDD then it will be optimized as you develop it.

If you just start developing it blindfolded you will get nowhere.

 

You NEED to have to in order to optimize. You can't write optimized code because optimization

depends in the wider spectrum of your project. Basic software engineering.

 

EDIT: I never said that l2j is optimized. It is pure shit but it has been tested over the years so you know

what performs better and what not.

Edited by .Elfocrash
Posted

Knownlist and AI are poor motivators.

 

Both can be reworked without trashing the rest, even if you plan going full custom.

 

But yeah you need to see how long it will take you to get there, it's nothing like adding a few skill or quest. We have a design for AI in mind for a while now, but it's risky :D

Posted (edited)

Knownlist and AI are poor motivators.

 

For a "rework from scratch" I fully agree. In fact any scenario is a poor motivator to rework all (even if you sum up all those little reworks). If L2J must be made from scratch it has either to be "insane performance boost" or "really easier design", otherwise I don't see the point.

 

Every single point stated as TODO (either by Mobius, me or UnAfraid/you) can be reworked one after the other, without having to build things from zero.

 

Ppl blames L2J but continue to use it, and when they try to do different and from scratch it ends as "L2JFree Genesis". If it's still used there is a reason, either none is enough brave to make it from zero (and even me, as a big reworker, I see no use to go that path) or there is no reason to do so. Pick your preference.

Edited by Tryskell
Posted

This forum is full of shit, lots of talking, lots of ideas.

 

All abandoned during the week. Please all of you deal with this fact and gtfo.

Posted (edited)

This forum is full of shit, lots of talking, lots of ideas.

 

All abandoned during the week. Please all of you deal with this fact and gtfo.

"Java is not VM language" - xDem 2016

 

E7wcB.gif

Edited by .Elfocrash

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now



  • Posts

    • A question: I’ve had two servers that were downgraded from C6 to C4, and both would lag for players when they changed subclass, and almost every time the L2 server would crash. They say it’s a problem with the C5 skills that were added. Has anyone experienced this issue? The server would run fine without errors until people started changing classes. Has anyone gone through this and knows the solution to the problem?
    • L2jBayev Chronicle 3: Rise of Darkness – AiEngine Edition In short: this is a C3 build with a full-fledged AI engine, live mercenaries, a built-in quiz, a “personal account” in the Community Board, and server logic neatly distributed across thread pools. The project is about a living world without lags : bots farm, communicate, gather parties, teleport along routes, and the server remains cold and stable.   What's inside (the most delicious) 1) Full-fledged AI engine for characters Behavior types: farming ( FarmAI ), combat ( CombatAI ), party logic ( PartyAI ), trading/walking ( TraderAI / WalkerAI ), support roles (healer, etc.). Class profiles: for mages/archers/daggers, etc., “smart” skill rotations, distance control, sleep/save skills, healing, loot pickup, etc. are implemented (see examples of classes like SpellSingerAI , NecromancerAI , etc.). Self-healing and teleports: when dying, the bot goes through a sequence of steps without sleep()- via AITaskSequence + AITeleportToLocTask , searches for the nearest gatekeeper and teleports via TeleportationManager with routes depending on the level. Auto-support: auto-nipples, arrows/bones, smart auto-proceduring of buffs and auto-banks CP/HP/MP with thresholds - all sewn into the auxiliary EtcPlayersAi . Chat context: ChatManagerAi processes mentions, makes responses with delays (anti-flood), supports party chat and “human” reaction. Understanding: ChatManagerAi system  processes the dialogue, bots remember your aggression and insults, they start to respond less often to modern users, stop accepting or inviting to a group (party) and when it goes beyond the peak they will simply merge you, and every time they see you on the PC, there is an opportunity to measure more often, communicate respectfully and beautifully, in general, a “human” reaction. Why a player/admin needs this: bots actually “live”, farm and interact, and don’t just stand on macros. This is a great background for online and PvE action.   2) Mercenaries (Mercenary system) Full-fledged companion character : L2MercenaryInstance with its own MercenaryAI (movement, attack, support, consumables, shots). Behavior modes: DEFENDER / SUPPORT / PASSIVE - switchable to suit your playing style. Progress and trust: the mercenary's trust/exp/level grows , skills are learned according to the MercenarySkillTree (conditions are based on the trust or level of the owner). Templates and equipment: via MercenaryTemplateTable and spawner - model/weapon/type are selected. Social: MercenarySpeechManager - a set of speeches; the mercenary "comes to life" in the chat. Premium Link: Premium account owners give the mercenary additional trust (faster progress). Why: This is not a dummy pet, but a playful companion with modes, training and “character”.   3) Quiz (event viktorina ) Rounds according to schedule: pre-launch with announcements (minutes/seconds before start), registration .reg, auto-opening of the window. Multiple choice questions: question + set of answer buttons; fair processing, timings, question change. Tops and history: results table, statistics, neat UI via HTML assembly. Flexible control: you can start immediately or set a delayed start (notification package 5/2/1 min, etc.). Why: regular activity for players, “social entertainment” module right in the build.   4) Personal account in Community Board KB managers: buff cabinet, teleports, clans/forums/mail/friends, tops (PK/PvP/wealth/players), character repair, viewing skill trees , etc. Premium logic: some services/mail are limited by premium; premium also affects the visual (nickname color) and bonuses (see effect on mercenary). Single sign-on: all in one place, no team chaos. Why: conveniently manage your character and services without going into the console or installing third-party mods.   Why is the system technically valuable? Minimum load and stability Separated thread pools: AI logic, hunting, teleports, chat - on separate onesScheduledExecutorService ( AI_THREAD_POOL , MONSTER_HUNT_POOL , TELEPORT_POOL , CHAT_POOL ). No "freezing": task sequencers (teleport/recovery) work through the scheduler, not Thread.sleep(). Bot limitation: protection against overload via thresholds/counters - “extra” bots do not start. One bot - one sequence: AITaskManager ensures that the character does not have parallel conflicting tasks. Smoothing out peaks: starting tasks with offsets so that there are no simultaneous “ticks” of hundreds of bots. Monitoring/logs: own loggers (separate files for info/errors/processes/chats), CPU load monitoring. Bottom line: the build is designed for “thick online” and mass activities without TPS failures .   Additional Features Auto-alliances for farming: party logic invites suitable players (checking level/equipment/clan flags), there are “human” responses to requests. Sub/class management: out of the box helpers for changing class/subclass, auto-learning of necessary skills and selection of equipment by level. Security/protection: secondary PIN/picture password support (used in KB/voiced commands; optional). Premium accounts: privileges in KB/mail/visual and synergy with mercenary progress. Ready-made services: tops, auctions/mail, teleports from KB, buff rooms, repairs, viewing skill trees, etc.   Who is this build for? Freeshare/project admins who want a living world “from the pack”: bots and mercenaries provide a constant background of activity. Players who value convenience: personal account, premium services, events and a mercenary companion. Developers who want a clean, predictable backend with thread pools and a neat task model without “magic”.   How it differs from standard assemblies Not macros - AI profiles with “brains”: rotations, positioning, healing, decision making. Not a decoration pet - a mercenary with his own modes, progress, skill tree and lines. Not a faceless gamemod - an event quiz with UI, schedule, tops. No chaos in flows - strict pools, planning and task managers designed for online and growth. No separate scripts - a single personal account in KB for most activities.   TL;DR (one paragraph for the project card) AiEngine C3 is a build with live AI, smart bots, mercenaries (modes/progress/skills), built-in quiz, premium logic and a convenient personal account in KB. Under the hood are distributed thread pools and task managers without sleep(), so even with a dense online the server remains stable and responsive.   Additionally add - there is still a lot of interesting things command .assassin or shift+target (order murder), shift+target for admins on AI characters for control, admin panel is completely rewritten, many additional functions, mercenaries change their appearance depending on trust, deepseek and chatGPT system is connected for communication of characters like real players, GPT - for newer java, there is still a very large list of fixes after the last versions, a lot has been fixed, including height coordinates (Z) geo-Squares, pathfinding, visibility through obstacles, fix pet summons, trade packages, shop packages, many effects, quests (including the original ones like nipples, etc.), Ai behavior of NPC and RB monsters, absolutely all epics have been transferred to AiLoader no longer in python scripts. Attention! The server is suitable for both classic mode and PvP format, as well as with various mods. Absolutely everything is configured in the configurations to suit your taste and purposes of use. It is recommended to launch the server through L2ServerControl (simplifies management and control of processes). Download Servers: Chronicle 3 Server Chronicle 4 Test Upgraded Server Full Desc & screens: Post & Screens c3 Post & Desc c4    
  • Topics

×
×
  • Create New...

AdBlock Extension Detected!

Our website is made possible by displaying online advertisements to our members.

Please disable AdBlock browser extension first, to be able to use our community.

I've Disabled AdBlock